std::basic_ifstream<CharT,Traits>::open
来自 cppreference.cn
< cpp | io | basic_ifstream
void open( const char* filename, = std::ios_base::in ); |
(1) | |
void open( const std::filesystem::path::value_type* filename, = std::ios_base::in ); |
(2) | (C++17 起) |
void open( const std::string& filename, = std::ios_base::in ); |
(3) | (C++11 起) |
void open( const std::filesystem::path& filename, = std::ios_base::in ); |
(4) | (C++17 起) |
打开文件,并将文件流与名为 filename 的文件关联起来。
成功时调用 clear()。失败时调用 setstate(failbit)。
1,2) 实际上调用 rdbuf()->open(filename, mode | ios_base::in)(有关该调用的详细信息,请参见 std::basic_filebuf::open)。 重载 (2) 仅在
std::filesystem::path::value_type
不是 char 时提供。(C++17 起)3,4) 实际上通过 open(filename.c_str(), mode) 调用 (1,2)。
目录 |
[编辑] 参数
filename | - | 要打开的文件名 | ||||||||||||||||
mode | - | 指定流的打开模式。它是一个 位掩码类型,定义了以下常量:
|
[编辑] 返回值
(无)
[编辑] 示例
本节不完整 原因:无示例 |
[编辑] 缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 发布时的行为 | 正确的行为 |
---|---|---|---|
LWG 22 | C++98 | 成功打开后错误状态如何变化不清楚 | 错误状态未改变 |
LWG 409 | C++98 | 成功打开后错误状态未改变 | 已清除[1] |
- ↑ LWG 问题 #22 的决议被覆盖。
[编辑] 另请参见
检查流是否关联了文件 (公共成员函数) | |
关闭关联的文件 (公共成员函数) | |
打开一个文件并将其配置为关联字符序列 ( std::basic_filebuf<CharT,Traits> 的公共成员函数) |