Namespaces
Variants

std::basic_filebuf<CharT,Traits>:: open

From cppreference.net
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

仅当 std::filesystem::path::value_type 不是 char 类型时,才提供重载 (4)

(C++17 起)

文件打开方式如同调用 std::fopen 函数,其第二个参数(文件访问模式)由 mode & ~ std:: ios_base :: ate 的运算结果决定,若结果不是下表中所示的标志组合, open() 函数将执行失败:

(注:根据要求,所有HTML标签、属性及 /
/标签内的内容(包括C++字符串字面量"w+b")均保留原文未翻译,表格中的"+"和"-"符号作为技术符号也未进行本地化处理)
(注:根据要求,表格中的符号"-"和"+"无需翻译,HTML结构和样式属性已完整保留) (说明:根据要求,仅对非代码/标签内容进行翻译。由于表格中仅包含符号"+"、"-"和C++字符串字面量"w+bx",这些内容均属于无需翻译范畴,故保持原文不变)
mode & ~ std:: ios_base :: ate  std::fopen 
访问
模式
文件已存在时的操作 文件不存在时的操作
binary 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 必须指向以空字符结尾的字符串
openmode - 文件打开模式,为 std::ios_base::openmode 模式按位或运算的结果

返回值

this 成功时返回该指针,失败时返回空指针。

注释

open() 通常通过构造函数或 open() 成员函数调用,该函数属于 std::basic_fstream

示例

#include <fstream>
#include <iostream>
int main()
{
    std::string filename = "Test.b";
    std::filebuf fb;
    // 准备要读取的文件
    double d = 3.14;
    if (!fb.open(filename, std::ios::binary | std::ios::out))
    {
        std::cout << "打开文件 " << filename << " 用于写入失败\n";
        return 1;
    } 
    fb.sputn(reinterpret_cast<char*>(&d), sizeof d);
    fb.close();
    // 打开文件用于读取
    double d2 = 0.0;
    if (!fb.open(filename, std::ios::binary | std::ios::in))
    {
        std::cout << "打开文件 " << filename << " 用于读取失败\n";
        return 1;
    }
    auto got = fb.sgetn(reinterpret_cast<char*>(&d2), sizeof d2);
    if (sizeof(d2) != got)
        std::cout << "读取 " << filename << " 失败\n";
    else
        std::cout << "从文件读取回的数据: " << d2 << '\n';
}

输出:

从文件读取回的数据: 3.14

缺陷报告

以下行为变更缺陷报告被追溯应用于先前发布的C++标准。

缺陷报告 适用标准 发布时行为 正确行为
LWG 596 C++98 open() 无法以追加模式打开文件 支持以追加模式打开

另请参阅

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