std::fclose
来自 cppreference.cn
| 定义于头文件 <cstdio> |
||
| int fclose( std::FILE* stream ); |
||
关闭给定的文件流,并将任何未写入的数据从 stream 的缓冲区写入关联的输出设备。任何未读取的缓冲数据都将被丢弃。
无论操作是否成功,该流都不再与文件关联,并且由 std::setbuf 或 std::setvbuf 分配的缓冲区(如果有)也将取消关联并在使用自动分配时解除分配。
|
如果任何数据被写入输出设备,从 |
(C++26 起) |
如果在 std::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("File opening failed"); return is_ok; } 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"); is_ok = EXIT_SUCCESS; } std::fclose(fp); return is_ok; }
输出
End of file reached successfully
[编辑] 参阅
| 打开文件 (函数) | |
| 用不同的名称打开一个现有流 (函数) | |
| 刷新输出缓冲区并关闭关联文件 ( std::basic_filebuf<CharT,Traits> 的公有成员函数) | |
| 有关 fclose 的C 文档
| |