std::fopen
来自cppreference.com
定义于头文件 <cstdio>
|
||
std::FILE* fopen( const char* filename, const char* mode ); |
||
打开 filename
所指示的文件并返回与该文件关联的流。用 mode
确定文件访问模式。
参数
filename | - | 要关联文件流到的文件名 | ||||||||||||||||||||||||||||||||||||||||||||||||||
mode | - | 确定文件访问模式的空终止字符串
|
返回值
若成功,则返回指向控制打开的文件流的对象的指针,并清除文件尾和错误位。流为完全缓冲,除非 filename 指代交互设备。
错误时,返回空指针。 POSIX 要求此情况下设置 errno 。
注意
filename
的格式是实现定义的,且不必指代一个文件(例如它可以是控制台或另一能通过文件系统 API 访问的设备)。在支持的平台上, filename
可包含绝对或相对文件系统路径。
可移植的目录和文件命名,见 C++ 文件系统库或 boost.filesystem 。
示例
运行此代码
#include <cstdio> #include <cstdlib> int main() { FILE* fp = std::fopen("test.txt", "r"); if(!fp) { std::perror("File opening failed"); return EXIT_FAILURE; } 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 error when reading"); else if (std::feof(fp)) std::puts("End of file reached successfully"); std::fclose(fp); }
参阅
关闭文件 (函数) | |
将输出流与实际文件同步 (函数) | |
以不同名称打开既存流 (函数) |