std::strstreambuf
来自cppreference.com
在标头 <strstream> 定义
|
||
class strstreambuf : public std::basic_streambuf<char> |
(C++98 中弃用) (C++26 中移除) |
|
std::strstreambuf
是关联字符序列为字符数组的 std::basic_streambuf,该数组可以是常量(例如字符串字面量),可修改但非动态的(例如栈分配的数组),或者动态的,此时 std::strstreambuf
可以重分配数组以适应输出(例如通过调用 delete[] 和 new[] 或用户提供的函数)。
std::strstreambuf
的典型实现保有四个私有数据成员:
1) 缓冲区状态,为位掩码类型,能表示四个值“已分配”(析构函数将解分配)、“常量”(不允许输出)、“动态”(输出将解分配)或“冻结”(不允许解分配和重分配)的任何组合;
2) 分配的缓冲区大小(缓冲区的起点不必是特别的数据成员,它可存储于继承的指针 eback());
3) 指向用户提供的分配函数的指针;
4) 指向用户提供的解分配函数的指针。
注解
在任何以动态缓冲区在流上调用 str() 后,要求调用 freeze(false) 以允许 strstreambuf
的析构函数在需要时解分配缓冲区。
strstreambuf
已于 C++98 起弃用并与 C++26 起移除。推荐的替代品是 std::spanbuf。 (C++23 起)
成员函数
公开成员函数 | |
构造 strstreambuf 对象 (公开成员函数) | |
[虚] |
销毁 strstreambuf 对象,部分情况下会解分配字符数组 (虚公开成员函数) |
设置/清除缓冲区的冻结状态 (公开成员函数) | |
标记缓冲为冻结并返回输入序列的起始指针 (公开成员函数) | |
返回输出序列中下一位置指针减起始指针:写入字符数 (公开成员函数) | |
受保护成员函数 | |
[虚] |
从输入序列读取一个字符而不前进下一位置指针 (虚受保护成员函数) |
[虚] |
回退输入序列以反获取一个字符 (虚受保护成员函数) |
[虚] |
后附字符到输出序列,可能重分配或初始地分配缓冲区,若它为动态且未被冻结 (虚受保护成员函数) |
[虚] |
尝试以数组替换受控制字符序列 (虚受保护成员函数) |
[虚] |
用相对寻址重寻位输入序列、输出序列或两者中的下一位置指针 (虚受保护成员函数) |
[虚] |
用绝对寻址重寻位输入序列、输出序列或两者中的下一位置指针 (虚受保护成员函数) |
继承自 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> 的公开成员函数) | |
获取区 | |
获得获取区中立即可用的字符数 ( 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> 的公开成员函数) | |
放置区 | |
写一个字符到放置区域,并推进下一位置指针 ( 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> 的虚受保护成员函数) |
[虚] |
从关联输入序列读取字符到获取区 ( 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> 的虚受保护成员函数) |