getc, getwc
leggere un carattere da un flusso.
int getc(
FILE *stream
);
wint_t getwc(
FILE *stream
);
Parametri
- stream
flusso di input.
Valore restituito
Restituisce il carattere lettura.Per indicare un errore di lettura o uno stato di fine file, getc restituisce EOFe getwc restituisce WEOF.per getc, utilizzare ferror o feof per verificare un errore o la presenza di fine del file.se stream viene NULL, getc e getwc richiamare il gestore non valido di parametro, come descritto in Convalida dei parametri.Se l'esecuzione è consentita per continuare, ritorno di queste funzioni EOF o WEOF pergetwc) e impostare errno in EINVAL.
vedere _doserrno, errno, _sys_errlist e _sys_nerr per ulteriori informazioni su questi e su altri, codici di errore.
Note
Ogni routine legge un singolo carattere da un file alla posizione corrente e incrementa il puntatore del file associato (se definito) per indicare il carattere successivo.Il file è associato stream.
Queste funzioni blocca il thread chiamante e sono pertanto thread-safe.per una versione non di blocco, vedere _getc_nolock, _getwc_nolock.
i commenti Routine-specifiche seguono.
routine |
Note |
---|---|
getc |
Equivale a fgetc, ma distribuito come funzione e come macro. |
getwc |
Versione a caratteri estesi di getc.Legge un carattere multibyte o un carattere di tipo " wide " seconda stream viene aperto in modalità testo o in modalità binario. |
Mapping di routine a testo generico
routine di TCHAR.H |
_UNICODE & _MBCS non definiti |
_MBCS definito |
_UNICODE definito |
---|---|---|---|
_gettc |
getc |
getc |
getwc |
Requisiti
routine |
Intestazione di associazione |
---|---|
getc |
<stdio.h> |
getwc |
<stdio.h> o <wchar.h> |
per informazioni di compatibilità aggiuntive, vedere compatibilità nell'introduzione.
Esempio
// crt_getc.c
// Use getc to read a line from a file.
#include <stdio.h>
int main()
{
char buffer[81];
int i, ch;
FILE* fp;
// Read a single line from the file "crt_getc.txt".
fopen_s(&fp, "crt_getc.txt", "r");
if (!fp)
{
printf("Failed to open file crt_getc.txt.\n");
exit(1);
}
for (i = 0; (i < 80) && ((ch = getc(fp)) != EOF)
&& (ch != '\n'); i++)
{
buffer[i] = (char) ch;
}
// Terminate string with a null character
buffer[i] = '\0';
printf( "Input was: %s\n", buffer);
fclose(fp);
}
input: crt_getc.txt
Line one.
Line two.
Output
Input was: Line one.