命名空间
变体
操作

std::basic_spanbuf

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

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

    : public std::basic_streambuf<CharT, Traits>
(自 C++23 起)

std::basic_spanbuf 是一个 std::basic_streambuf,其关联的字符序列是驻留在内存中的任意字符序列,可以从 std::span<CharT> 实例初始化或作为 std::span<CharT> 实例提供。

std::basic_spanbuf 在固定缓冲区上执行 I/O,因此当底层缓冲区耗尽时它不会尝试获取新缓冲区。

提供了几种用于常见字符类型的 typedef

定义在头文件 <spanstream>
类型 定义
std::spanbuf std::basic_spanbuf<char>
std::wspanbuf std::basic_spanbuf<wchar_t>

内容

[编辑] 成员类型

成员类型 定义
char_type CharT[edit]
traits_type Traits; 如果 Traits::char_type 不是 CharT,则程序格式错误。[edit]
int_type Traits::int_type[edit]
pos_type Traits::pos_type[edit]
off_type Traits::off_type[edit]

[编辑] 数据成员

成员名称 定义
mod (私有) 一个 std::ios_base::openmode,记录打开模式。
(仅供说明的成员对象*)
buf (私有) 一个 std::span<CharT>,引用底层缓冲区。
(仅供说明的成员对象*)

[编辑] 成员函数

公共成员函数
构造 basic_spanbuf 对象
(公共成员函数) [edit]
(析构函数)
[虚函数] (C++23)
销毁 basic_spanbuf 对象
(虚拟公共成员函数)
(C++23)
分配 basic_spanbuf 对象
(公共成员函数) [edit]
(C++23)
交换两个 basic_spanbuf 对象
(公共成员函数) [edit]
(C++23)
根据模式获取或初始化底层缓冲区
(公共成员函数) [edit]
受保护成员函数
[虚函数] (C++23)
尝试用数组替换控制的字符序列
(虚拟受保护成员函数) [edit]
[虚函数] (C++23)
使用相对寻址重新定位输入序列、输出序列或两者中的下一个指针
(虚拟受保护成员函数) [edit]
[虚函数] (C++23)
使用绝对寻址重新定位输入序列、输出序列或两者中的下一个指针
(虚拟受保护成员函数) [edit]

[编辑] 非成员函数

专门化了 std::swap 算法
(函数模板) [edit]

std::basic_streambuf 继承

成员类型

成员类型 定义
char_type CharT[edit]
traits_type Traits; 如果 Traits::char_type 不是 CharT,则程序格式错误。[edit]
int_type Traits::int_type[edit]
pos_type Traits::pos_type[edit]
off_type Traits::off_type[edit]

成员函数

销毁 basic_streambuf 对象
(std::basic_streambuf<CharT,Traits> 的虚拟公共成员函数) [edit]
区域设置
调用 imbue()
(std::basic_streambuf<CharT,Traits> 的公共成员函数) [edit]
获取关联区域设置的副本
(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> 的虚拟受保护的成员函数) [编辑]

[编辑] 注释

std::basic_spanbuf 不拥有底层缓冲区。

程序员有责任确保底层缓冲区在 std::basic_spanbuf 对象使用它时处于其生命周期中。如果多个线程通过不同的 std::basic_spanbuf 对象操作相同的底层缓冲区,则可能需要额外的同步。

特性测试 Std 特性
__cpp_lib_spanstream 202106L (C++23) std::spanbuf, std::spanstream

[编辑] 另请参阅

实现原始字符串设备
(类模板) [编辑]
(C++98 中已弃用)(C++26 中已移除)
实现原始字符数组设备
(类) [编辑]