命名空间
变体
操作

std::basic_filebuf

来自 cppreference.com
< cpp‎ | io
 
 
 
 
定义在头文件 <fstream>
template<

    class CharT,
    class Traits = std::char_traits<CharT>

> class basic_filebuf : public std::basic_streambuf<CharT, Traits>

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 对象
(公有成员函数) [编辑]
返回底层的实现定义的句柄
(公有成员函数) [编辑]
析构一个 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) [编辑]