fclose

来自cppreference.com
< c‎ | io
定义于头文件 <stdio.h>
int fclose( FILE *stream );

关闭给定的文件流。任何未写入的缓冲数据被冲入输出流。任何未读取的缓冲数据被忽略。

无论操作是否成功,该流都不再关联到文件,且setbufsetvbuf所分配的缓冲区若存在,则亦被解除关联,若使用自动分配则被解除分配。

若在fclose返回后使用指针stream的值,则行为未定义。

目录

[编辑] 参数

stream - 需要关闭的文件流

[编辑] 返回值

成功时为0,否则为EOF

[编辑] 示例

#include <stdio.h>
#include <stdlib.h>
 
int main(void)
{
    FILE* fp = fopen("test.txt", "r");
    if(!fp) {
        perror("File opening failed");
        return EXIT_FAILURE;
    }
 
    int c; // 注意:int,非char,要求处理EOF
    while ((c = fgetc(fp)) != EOF) { // 标准C I/O读取文件循环
       putchar(c);
    }
 
    if (ferror(fp))
        puts("I/O error when reading");
    else if (feof(fp))
        puts("End of file reached successfully");
 
    fclose(fp);
}


[编辑] 参考

  • C11 standard (ISO/IEC 9899:2011):
  • 7.21.5.1 The fclose function (p: 304)
  • C99 standard (ISO/IEC 9899:1999):
  • 7.19.5.1 The fclose function (p: 270)
  • C89/C90 standard (ISO/IEC 9899:1990):
  • 4.9.5.1 The fclose function

[编辑] 参阅

打开文件
(函数) [edit]
以不同名称打开既存的文件流
(函数) [edit]
fcloseC++文档