命名空间
变体
操作

std::basic_stringbuf

来自 cppreference.cn
< cpp‎ | io
 
 
 
 
定义于头文件 <sstream>
template<

    class CharT,
    class Traits = std::char_traits<CharT>,
    class Allocator = std::allocator<CharT>
> class basic_stringbuf

    : public std::basic_streambuf<CharT, Traits>

std::basic_stringbuf 是一个 std::basic_streambuf,其关联的字符序列是驻留在内存中的任意字符序列,可以从 std::basic_string 的实例初始化或用作该实例。

std::basic_stringbuf 的典型实现直接将 std::basic_string 类型或等效的可调整大小的序列容器对象作为数据成员持有,并将其同时用作受控字符序列(std::basic_streambuf 的六个指针指向的数组)和关联的字符序列(所有输入操作的字符源和输出的目标)。

此外,典型的实现还会持有一个 std::ios_base::openmode 类型的数据成员,以指示关联流的 I/O 模式(仅输入、仅输出、输入/输出、末尾等)。

如果 overflow() 使用了过度分配策略,则可能会存储一个额外的高水位线指针来跟踪最后初始化的字符。

(C++11 起)

为常见的字符类型提供了几个 typedef

定义于头文件 <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 对象
(公共成员函数) [编辑]
(析构函数)
[virtual] (隐式声明)
析构 basic_stringbuf 对象及其持有的字符串
(虚公共成员函数) [编辑]
替换或获取关联字符字符串的副本
(公共成员函数) [编辑]
获取与内部序列容器关联的分配器的副本
(公共成员函数) [编辑]
(C++20)
获取底层字符序列的视图
(公共成员函数) [编辑]

[编辑] 受保护成员函数

[virtual]
返回输入序列中可用的下一个字符
(虚受保护成员函数) [编辑]
[virtual]
将字符放回输入序列
(虚受保护成员函数) [编辑]
[virtual]
将字符附加到输出序列
(虚受保护成员函数) [编辑]
[virtual]
尝试用数组替换受控字符序列
(虚受保护成员函数) [编辑]
[virtual]
使用相对寻址重新定位输入序列、输出序列或两者的下一个指针
(虚受保护成员函数) [编辑]
[virtual]
使用绝对寻址重新定位输入序列、输出序列或两者的下一个指针
(虚受保护成员函数) [编辑]

[编辑] 非成员函数

特化 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> 的公共成员函数) [编辑]
读取区域
获取读取区域中立即可用的字符数
(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 对象
(受保护成员函数) [编辑]
区域设置
[virtual]
对关联区域设置的更改做出反应
(std::basic_streambuf<CharT,Traits> 的虚受保护成员函数) [编辑]
定位
[virtual]
如果允许,用用户定义的数组替换缓冲区
(std::basic_streambuf<CharT,Traits> 的虚受保护成员函数) [编辑]
[virtual]
使用相对寻址重新定位输入序列、输出序列或两者的下一个指针
(std::basic_streambuf<CharT,Traits> 的虚受保护成员函数) [编辑]
[virtual]
使用绝对寻址重新定位输入序列、输出序列或两者的下一个指针
(std::basic_streambuf<CharT,Traits> 的虚受保护成员函数) [编辑]
[virtual]
将缓冲区与关联的字符序列同步
(std::basic_streambuf<CharT,Traits> 的虚受保护成员函数) [编辑]
读取区域
[virtual]
如果已知,获取关联输入序列中可用于输入的字符数
(std::basic_streambuf<CharT,Traits> 的虚受保护成员函数) [编辑]
[virtual]
从关联的输入序列读取字符到读取区域
(std::basic_streambuf<CharT,Traits> 的虚受保护成员函数) [编辑]
[virtual]
从关联的输入序列读取字符到读取区域,并前进下一个指针
(std::basic_streambuf<CharT,Traits> 的虚受保护成员函数) [编辑]
[virtual]
从输入序列读取多个字符
(std::basic_streambuf<CharT,Traits> 的虚受保护成员函数) [编辑]
返回指向读取区域的开始、当前字符和结尾的指针
(受保护成员函数) [编辑]
前进输入序列中的下一个指针
(受保护成员函数) [编辑]
重新定位输入序列的开始、下一个和结尾指针
(受保护成员函数) [编辑]
写入区域
[virtual]
将多个字符写入输出序列
(std::basic_streambuf<CharT,Traits> 的虚受保护成员函数) [编辑]
[virtual]
将字符从写入区域写入关联的输出序列
(std::basic_streambuf<CharT,Traits> 的虚受保护成员函数) [编辑]
返回指向写入区域的开始、当前字符和结尾的指针
(受保护成员函数) [编辑]
前进输出序列的下一个指针
(受保护成员函数) [编辑]
重新定位输出序列的开始、下一个和结尾指针
(受保护成员函数) [编辑]
放回
[virtual]
将字符放回输入序列,可能会修改输入序列
(std::basic_streambuf<CharT,Traits> 的虚受保护成员函数) [编辑]