feof
Testuje ukončení souboru ve streamu.
Syntaxe
int feof(
FILE *stream
);
Parametry
stream
Ukazatel na FILE
strukturu.
Vrácená hodnota
Funkce feof
vrátí nenulovou hodnotu, pokud se operace čtení pokusila přečíst po konci souboru; v opačném případě vrátí hodnotu 0. Pokud je NULL
ukazatel datového proudu , funkce vyvolá neplatnou obslužnou rutinu parametru, jak je popsáno v ověření parametru. Pokud je povoleno pokračovat spuštěním, errno
je nastaveno na EINVAL
hodnotu a feof
vrátí hodnotu 0.
Další informace o návratových kódech naleznete v tématu errno
, _doserrno
, _sys_errlist
a _sys_nerr
.
Poznámky
Rutina feof
(implementovaná jako funkce i makro) určuje, zda byl konec stream
předán. Po předání konce souboru vrátí operace čtení indikátor konce souboru, dokud se datový proud zavře nebo dokud rewind
, fsetpos
, fseek
nebo clearerr
je volána proti němu.
Pokud například soubor obsahuje 10 bajtů a 10 bajtů ze souboru přečtete, vrátí hodnotu 0, feof
protože i když je ukazatel souboru na konci souboru, nepokoušli jste se přečíst za koncem. Až po pokusu o přečtení 11. bajtu vrátí feof
nenulovou hodnotu.
Ve výchozím nastavení je globální stav této funkce vymezen na aplikaci. Chcete-li toto chování změnit, přečtěte si téma Globální stav v CRT.
Požadavky
Function | Požadovaný hlavičkový soubor |
---|---|
feof |
<stdio.h> |
Další informace o kompatibilitě najdete v tématu Kompatibilita.
Příklad
// crt_feof.c
// This program uses feof to indicate when
// it reaches the end of the file CRT_FEOF.TXT. It also
// checks for errors with ferror.
//
#include <stdio.h>
#include <stdlib.h>
int main( void )
{
int count, total = 0;
char buffer[100];
FILE *stream;
fopen_s( &stream, "crt_feof.txt", "r" );
if( stream == NULL )
exit( 1 );
// Cycle until end of file reached:
while( !feof( stream ) )
{
// Attempt to read in 100 bytes:
count = fread( buffer, sizeof( char ), 100, stream );
if( ferror( stream ) ) {
perror( "Read error" );
break;
}
// Total up actual bytes read
total += count;
}
printf( "Number of bytes read = %d\n", total );
fclose( stream );
}
Vstup: crt_feof.txt
Line one.
Line two.
Výstup
Number of bytes read = 19
Viz také
Zpracování chyb
Vstupně-výstupní operace streamu
clearerr
_eof
ferror
perror
, _wperror