std::fclose

来自cppreference.com
< cpp‎ | io‎ | c
 
 
 
 
在标头 <cstdio> 定义
int fclose( std::FILE* stream );

关���给定的文件流,并将来自 stream 缓冲区的未写入数据写入关联的输出设备。舍弃任何尚未读取的缓冲数据。

无论操作是否成功,流都不再关联到文件,且由 std::setbufstd::setvbuf 分配的缓冲区(如果存在)也会被解除关联,并且在使用自动分配时会被解分配。

如果有数据被写入输出设备,那么从 std::fclose 返回会建立一个可观察检查点

(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("打开文件失败");
        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> 的公开成员函数) [编辑]
fclose 的 C 文档