std::fclose
来自cppreference.com
在标头 <cstdio> 定义
|
||
int fclose( std::FILE* stream ); |
||
关闭给定的文件流。冲洗任何尚未写入的缓冲数据到 OS。舍弃任何尚未读取的缓冲数据。
无论操作是否成功,流都不再关联到文件,且由 std::setbuf 或 std::setvbuf 分配的缓冲区若存在,则亦被解除关联,并且若使用自动分配则被解分配。
若在 fclose
返回后使用 stream 的值则行为未定义。
参数
stream | - | 要关闭的文件流 |
返回值
成功时为 0,否则为 EOF。
示例
运行此代码
#include <cstdio> #include <cstdlib> int main() { int is_ok = EXIT_FAILURE; FILE* fp = std::fopen("/tmp/test.txt", "w+"); if (!fp) { std::perror("打开文件失败"); return is_ok; } int c; // 注意:是 int 而非 char,处理 EOF 所必须 while ((c = std::fgetc(fp)) != EOF) // 标准 C I/O 文件读取循环 std::putchar(c); if (std::ferror(fp)) std::puts("读取时发生了 I/O 错误"); else if (std::feof(fp)) { std::puts("成功抵达文件末尾"); is_ok = EXIT_SUCCESS; } std::fclose(fp); return is_ok; }
输出:
成功抵达文件末尾
参阅
打开文件 (函数) | |
以不同名称打开既存流 (函数) | |
冲洗放置区缓冲区并关闭关联的文件 ( std::basic_filebuf<CharT,Traits> 的公开成员函数) |