Defined in header <cstdio> | ||
---|---|---|
int fclose( std::FILE* stream ); |
Closes the given file stream. Any unwritten buffered data are flushed to the OS. Any unread buffered data are discarded.
Whether or not the operation succeeds, the stream is no longer associated with a file, and the buffer allocated by std::setbuf
or std::setvbuf
, if any, is also disassociated and deallocated if automatic allocation was used.
Parameters
stream | - | the file stream to close |
Return value
0
on success, EOF
otherwise.
Example
#include <cstdio> #include <cstdlib> int main() { FILE* fp = std::fopen("test.txt", "r"); if(!fp) { std::perror("File opening failed"); return EXIT_FAILURE; } int c; // note: int, not char, required to handle EOF while ((c = std::fgetc(fp)) != EOF) { // standard C I/O file reading loop std::putchar(c); } if (std::ferror(fp)) std::puts("I/O error when reading"); else if (std::feof(fp)) std::puts("End of file reached successfully"); std::fclose(fp); }
See also
opens a file (function) | |
open an existing stream with a different name (function) | |
flushes the put area buffer and closes the associated file (public member function of std::basic_filebuf ) | |
C documentation for fclose |
Please login to continue.