std::basic_stringbuf
来自 cppreference.com
定义在头文件 <sstream> 中 |
||
template< class CharT, |
||
std::basic_stringbuf
是一个 std::basic_streambuf,其关联的字符序列是内存驻留的任意字符序列,可以从 std::basic_string 实例初始化,也可以作为 std::basic_string 实例提供。
std::basic_stringbuf
的典型实现直接将类型为 std::basic_string 或等效可调整大小序列容器的对象作为数据成员,并将其用作受控字符序列(std::basic_streambuf 的六个指针指向的数组)和关联字符序列(所有输入操作的字符源和输出的目标)。
此外,典型实现会保存类型为 std::ios_base::openmode 的数据成员,以指示关联流的 I/O 模式(仅输入、仅输出、输入/输出、在末尾等)。
如果 overflow() 使用超额分配策略,则可以存储额外的最高水位指针来跟踪最后初始化的字符。 |
(从 C++11 起) |
为常用字符类型提供了多个类型定义
定义在头文件
<sstream> 中 | |
类型 | 定义 |
std::stringbuf
|
std::basic_stringbuf<char> |
std::wstringbuf
|
std::basic_stringbuf<wchar_t> |
内容 |
[编辑] 成员类型
成员类型 | 定义 |
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 |
allocator_type
|
Allocator |
[编辑] 仅供说明的成员
buf |
用作底层缓冲区的 std::basic_string<CharT, Traits, Allocator> (仅供说明的成员对象*) |
mode |
关联流的 std::ios_base::openmode (仅供说明的成员对象*) |
初始化输入和输出序列 (仅供说明的成员函数*) |
[编辑] 公有成员函数
构造 basic_stringbuf 对象(公有成员函数) | |
(C++11) |
分配 basic_stringbuf 对象(公有成员函数) |
(C++11) |
交换两个 basic_stringbuf 对象(公有成员函数) |
(析构函数) [虚拟] (隐式声明) |
析构 basic_stringbuf 对象及其持有的字符串(虚拟公有成员函数) |
替换或获取关联字符字符串的副本 (公有成员函数) | |
(C++20) |
获取与内部序列容器关联的分配器的副本 (公有成员函数) |
(C++20) |
获取底层字符序列的视图 (公有成员函数) |
[编辑] 保护成员函数
[虚拟] |
返回输入序列中可用的下一个字符 (虚拟保护成员函数) |
[虚拟] |
将一个字符放回输入序列 (虚拟保护成员函数) |
[虚拟] |
将一个字符追加到输出序列 (虚拟保护成员函数) |
[虚拟] |
尝试用一个数组替换受控字符序列 (虚拟保护成员函数) |
[虚拟] |
使用相对寻址方式重新定位输入序列、输出序列或两者的下一个指针 (虚拟保护成员函数) |
[虚拟] |
使用绝对寻址方式重新定位输入序列、输出序列或两者的下一个指针 (虚拟保护成员函数) |
[编辑] 非成员函数
专门化了 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 区域并推进下一个指针 ( 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> 的虚拟保护成员函数) |
返回指向 get 区域的开头、当前字符和结尾的指针 (受保护的成员函数) | |
将输入序列中的下一个指针向前移动 (受保护的成员函数) | |
重新定位输入序列的开始、下一个和结束指针 (受保护的成员函数) | |
放入区域 | |
[虚拟] |
将多个字符写入输出序列 ( std::basic_streambuf<CharT,Traits> 的虚拟受保护成员函数) |
[虚拟] |
从输出区域将字符写入关联的输出序列 ( std::basic_streambuf<CharT,Traits> 的虚拟受保护成员函数) |
返回指向输出区域的开始、当前字符和结束的指针 (受保护的成员函数) | |
将输出序列的下一个指针向前移动 (受保护的成员函数) | |
重新定位输出序列的开始、下一个和结束指针 (受保护的成员函数) | |
放回 | |
[虚拟] |
将一个字符放回输入序列,可能会修改输入序列 ( std::basic_streambuf<CharT,Traits> 的虚拟受保护成员函数) |