std::basic_filebuf<CharT,Traits>::open
来自 cppreference.com
< cpp | io | basic filebuf
basic_filebuf* open( const char* s, std::ios_base::openmode mode ); |
(1) | |
basic_filebuf* open( const std::string& str, std::ios_base::openmode mode ); |
(2) | (自 C++11 起) |
basic_filebuf* open( const std::filesystem::path& p, std::ios_base::openmode mode ); |
(3) | (自 C++17 起) |
basic_filebuf* open( const std::filesystem::path::value_type* s, std::ios_base::openmode mode ); |
(4) | (自 C++17 起) |
如果关联文件已经打开 (is_open() != false), 立即返回空指针。
否则,使用给定名称 (s, p.c_str()(自 C++17 起) 或 str.c_str(), 具体取决于重载) 打开文件。 std::ios_base::openmode 值可以写成,例如,std::ios_base::out | std::ios_base::app.
重载 (4) 仅在 |
(自 C++17 起) |
该文件是通过使用第二个参数 (文件访问模式) 调用 std::fopen 打开的,该参数由 mode & ~std::ios_base::ate 的结果确定,如下所示,如果结果不是表中显示的标志的某种组合,则 open()
失败
mode & ~std::ios_base::ate | std::fopen 访问 模式 |
如果文件已存在,则执行操作 | 如果文件不存在,则执行操作 | |||||
---|---|---|---|---|---|---|---|---|
二进制 | in | out | trunc | app | noreplace (自 C++23 起) | |||
- | + | - | - | - | - | "r" | 从开头读取 | 打开失败 |
+ | + | - | - | - | - | "rb" | ||
- | + | + | - | - | - | "r+" | 错误 | |
+ | + | + | - | - | - | "r+b" | ||
- | - | + | - | - | - | "w" | 销毁内容 | 创建新文件 |
- | - | + | + | - | - | |||
+ | - | + | - | - | - | "wb" | ||
+ | - | + | + | - | - | |||
- | + | + | + | - | - | "w+" | ||
+ | + | + | + | - | - | "w+b" | ||
- | - | + | - | - | + | "wx" | 打开失败 | 创建新文件 |
- | - | + | + | - | + | |||
+ | - | + | - | - | + | "wbx" | ||
+ | - | + | + | - | + | |||
- | + | + | + | - | + | "w+x" | ||
+ | + | + | + | - | + | "w+bx" | ||
- | - | + | - | + | - | "a" | 写入结尾 | 创建新文件 |
- | - | - | - | + | - | |||
+ | - | + | - | + | - | "ab" | ||
+ | - | - | - | + | - | |||
- | + | + | - | + | - | "a+" | ||
- | + | - | - | + | - | |||
+ | + | + | - | + | - | "a+b" | ||
+ | + | - | - | + | - |
如果打开操作成功并且 (openmode & std::ios_base::ate) != 0 (ate
位已设置),将文件位置重新定位到文件结尾,就像调用 std::fseek(file, 0, SEEK_END) 一样,其中 file 是通过调用 std::fopen 返回的指针。如果重新定位失败,则调用 close() 并返回一个空指针以指示失败。
内容 |
[编辑] 参数
s, str, p | - | 要打开的文件名;s 必须指向一个以 null 结尾的字符串 |
openmode | - | 文件打开模式,是 std::ios_base::openmode 模式进行二进制或运算的结果 |
[编辑] 返回值
成功时为 this,失败时为一个空指针。
[编辑] 注释
open()
通常通过 std::basic_fstream 的构造函数或 open()
成员函数来调用。
[编辑] 示例
运行此代码
#include <fstream> #include <iostream> int main() { std::string filename = "Test.b"; std::filebuf fb; // prepare a file to read double d = 3.14; if (!fb.open(filename, std::ios::binary | std::ios::out)) { std::cout << "Open file " << filename << " for write failed\n"; return 1; } fb.sputn(reinterpret_cast<char*>(&d), sizeof d); fb.close(); // open file for reading double d2 = 0.0; if (!fb.open(filename, std::ios::binary | std::ios::in)) { std::cout << "Open file " << filename << " for read failed\n"; return 1; } auto got = fb.sgetn(reinterpret_cast<char*>(&d2), sizeof d2); if (sizeof(d2) != got) std::cout << "Read of " << filename << " failed\n"; else std::cout << "Read back from file: " << d2 << '\n'; }
输出
Read back from file: 3.14
[编辑] 缺陷报告
以下行为变更缺陷报告已追溯应用于以前发布的 C++ 标准。
DR | 应用于 | 发布的行为 | 正确行为 |
---|---|---|---|
LWG 596 | C++98 | open() 无法以追加模式打开文件 |
可以以追加模式打开 |
[编辑] 另请参见
检查关联文件是否打开 (公有成员函数) | |
刷新输出区域缓冲区并关闭关联文件 (公有成员函数) |