命名空间
变体
操作

std::fclose

来自 cppreference.cn
< 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("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> 的公有成员函数) [编辑]
有关 fcloseC 文档