命名空间
变体
操作

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) 仅在 std::filesystem::path::value_type 不是 char 时提供。

(自 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() 无法以追加模式打开文件 可以以追加模式打开

[编辑] 另请参见

检查关联文件是否打开
(公有成员函数) [编辑]
刷新输出区域缓冲区并关闭关联文件
(公有成员函数) [编辑]