std::basic_filebuf
来自 cppreference.com
定义在头文件 <fstream> 中 |
||
template< class CharT, |
||
std::basic_filebuf
是一个 std::basic_streambuf,其关联的字符序列是一个文件。输入序列和输出序列都与同一个文件关联,并且为两种操作维护一个联合文件位置。对使用 std::basic_filebuf
读取和写入序列的限制与 std::FILE 相同。
函数 underflow() 和 overflow() / sync() 在文件和缓冲区的获取区域和放置区域之间执行实际的 I/O。当 CharT
不是 char 时,大多数实现将多字节字符存储在文件中,并且使用 std::codecvt 面进行宽字节/多字节字符转换。
为常见的字符类型提供了几个类型定义
定义在头文件
<streambuf> 中 | |
类型 | 定义 |
std::filebuf
|
std::basic_filebuf<char> |
std::wfilebuf
|
std::basic_filebuf<wchar_t> |
内容 |
[编辑] 成员类型
成员类型 | 定义 |
char_type
|
CharT |
traits_type
|
Traits ; 如果 Traits::char_type 不是 CharT ,则程序格式不正确。 |
int_type
|
Traits::int_type |
pos_type
|
Traits::pos_type ,它需要是 std::fpos<Traits::state_type> |
off_type
|
Traits::off_type |
native_handle_type (C++26) |
实现定义的类型,它是 TriviallyCopyable 并且 semiregular |
[编辑] 成员函数
公有成员函数 | |
构造一个 basic_filebuf 对象(公有成员函数) | |
(C++11) |
分配一个 basic_filebuf 对象(公有成员函数) |
(C++11) |
交换两个 basic_filebuf 对象(公有成员函数) |
(C++26) |
返回底层的实现定义的句柄 (公有成员函数) |
[虚拟] |
析构一个 basic_filebuf 对象,如果文件处于打开状态,则关闭文件(虚拟公有成员函数) |
检查关联的文件是否打开 (公有成员函数) | |
打开一个文件并将其配置为关联的字符序列 (公有成员函数) | |
刷新放置区域缓冲区并关闭关联的文件 (公有成员函数) | |
保护成员函数 | |
[虚拟] |
可选地提供从文件中可供输入的字符数 (虚拟保护成员函数) |
[虚拟] |
从关联的文件中读取 (虚拟保护成员函数) |
[虚拟] |
从关联的文件中读取并推进获取区域中的下一个指针 (虚拟保护成员函数) |
[虚拟] |
将输入序列回退以取消获取一个字符,不影响关联的文件 (虚拟保护成员函数) |
[虚拟] |
从 put 区域写入字符到关联文件 (虚拟保护成员函数) |
[虚拟] |
提供用户提供的缓冲区或将此 filebuf 设置为无缓冲区 (虚拟保护成员函数) |
[虚拟] |
使用相对寻址重新定位文件位置 (虚拟保护成员函数) |
[虚拟] |
使用绝对寻址重新定位文件位置 (虚拟保护成员函数) |
[虚拟] |
从 put 区域写入字符到关联文件 (虚拟保护成员函数) |
[虚拟] |
更改关联的区域设置 (虚拟保护成员函数) |
[编辑] 非成员函数
专门化 std::swap 算法 (函数模板) |
继承自 std::basic_streambuf
成员类型
成员类型 | 定义 |
char_type
|
CharT |
traits_type
|
Traits ; 如果 Traits::char_type 不是 CharT ,则程序格式不正确。 |
int_type
|
Traits::int_type |
pos_type
|
Traits::pos_type |
off_type
|
Traits::off_type |
成员函数
[虚拟] |
析构 basic_streambuf 对象( std::basic_streambuf<CharT,Traits> 的虚拟公共成员函数) |
区域设置 | |
调用 imbue() ( std::basic_streambuf<CharT,Traits> 的公共成员函数) | |
获取关联区域设置的副本 ( std::basic_streambuf<CharT,Traits> 的公共成员函数) | |
定位 | |
调用 setbuf() ( std::basic_streambuf<CharT,Traits> 的公共成员函数) | |
调用 seekoff() ( std::basic_streambuf<CharT,Traits> 的公共成员函数) | |
调用 seekpos() ( std::basic_streambuf<CharT,Traits> 的公共成员函数) | |
调用 sync() ( std::basic_streambuf<CharT,Traits> 的公共成员函数) | |
获取区域 | |
获取 get 区域中立即可用的字符数 ( std::basic_streambuf<CharT,Traits> 的公共成员函数) | |
推进输入序列,然后读取一个字符而不再次推进 ( std::basic_streambuf<CharT,Traits> 的公共成员函数) | |
(在 C++17 中移除) |
从输入序列读取一个字符并推进序列 ( std::basic_streambuf<CharT,Traits> 的公共成员函数) |
从输入序列读取一个字符而不推进序列 ( std::basic_streambuf<CharT,Traits> 的公共成员函数) | |
调用 xsgetn() ( std::basic_streambuf<CharT,Traits> 的公共成员函数) | |
put 区域 | |
将一个字符写入 put 区域并推进下一个指针 ( std::basic_streambuf<CharT,Traits> 的公共成员函数) | |
调用 xsputn() ( std::basic_streambuf<CharT,Traits> 的公共成员函数) | |
回退 | |
将一个字符放回输入序列 ( std::basic_streambuf<CharT,Traits> 的公共成员函数) | |
将输入序列中的下一个指针向后移动一个 ( std::basic_streambuf<CharT,Traits> 的公共成员函数) |
保护成员函数
构造 basic_streambuf 对象(保护成员函数) | |
(C++11) |
替换 basic_streambuf 对象(保护成员函数) |
(C++11) |
交换两个 basic_streambuf 对象(保护成员函数) |
区域设置 | |
[虚拟] |
更改关联的区域设置 ( std::basic_streambuf<CharT,Traits> 的虚拟保护成员函数) |
定位 | |
[虚拟] |
如果允许,用用户定义的数组替换缓冲区 ( std::basic_streambuf<CharT,Traits> 的虚拟保护成员函数) |
[虚拟] |
使用相对寻址重新定位输入序列、输出序列或二者的下一个指针 ( std::basic_streambuf<CharT,Traits> 的虚拟保护成员函数) |
[虚拟] |
使用绝对寻址重新定位输入序列、输出序列或二者的下一个指针 ( std::basic_streambuf<CharT,Traits> 的虚拟保护成员函数) |
[虚拟] |
将缓冲区与关联的字符序列同步 ( std::basic_streambuf<CharT,Traits> 的虚拟保护成员函数) |
获取区域 | |
[虚拟] |
获取关联的输入序列中可用于输入的字符数,如果已知 ( std::basic_streambuf<CharT,Traits> 的虚拟保护成员函数) |
[虚拟] |
从关联的输入序列读取字符到 get 区域 ( std::basic_streambuf<CharT,Traits> 的虚拟保护成员函数) |
[虚拟] |
从关联的输入序列读取字符到 get 区域并推进下一个指针 ( std::basic_streambuf<CharT,Traits> 的虚拟保护成员函数) |
[虚拟] |
从输入序列读取多个字符 ( std::basic_streambuf<CharT,Traits> 的虚拟保护成员函数) |
返回指向获取区域的开头、当前字符和结尾的指针 (受保护的成员函数) | |
将输入序列中的下一个指针向前移动 (受保护的成员函数) | |
重新定位输入序列的开头、下一个和结束指针 (受保护的成员函数) | |
put 区域 | |
[虚拟] |
将多个字符写入输出序列 ( std::basic_streambuf<CharT,Traits> 的虚拟受保护成员函数) |
[虚拟] |
将字符从放置区域写入关联的输出序列 ( std::basic_streambuf<CharT,Traits> 的虚拟受保护成员函数) |
返回指向放置区域的开头、当前字符和结尾的指针 (受保护的成员函数) | |
将输出序列的下一个指针向前移动 (受保护的成员函数) | |
重新定位输出序列的开头、下一个和结束指针 (受保护的成员函数) | |
回退 | |
[虚拟] |
将一个字符放回输入序列中,可能会修改输入序列 ( std::basic_streambuf<CharT,Traits> 的虚拟受保护成员函数) |
[编辑] 注释
特性测试 宏 | 值 | Std | 特性 |
---|---|---|---|
__cpp_lib_fstream_native_handle |
202306L | (C++26) | 原生句柄支持 |
[编辑] 另请参见
对象类型,能够保存控制 C I/O 流所需的所有信息 (typedef) |