std:: basic_spanbuf
|
定义于头文件
<spanstream>
|
||
|
template
<
class
CharT,
|
(C++23 起) | |
std::basic_spanbuf
是一个
std::basic_streambuf
,其关联的字符序列是内存驻留的任意字符序列,该序列可以从
std::
span
<
CharT
>
实例初始化或作为其实例提供。
std::basic_spanbuf
在固定缓冲区上执行I/O操作,因此当底层缓冲区耗尽时不会尝试获取新缓冲区。
提供了几种常见字符类型的类型定义:
|
定义于头文件
<spanstream>
|
|
| 类型 | 定义 |
std::spanbuf
|
std :: basic_spanbuf < char > |
std::wspanbuf
|
std :: basic_spanbuf < 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
|
数据成员
| 成员名称 | 定义 |
mod
(私有)
|
记录打开模式的
std::ios_base::openmode
类型对象。
( 说明专用成员对象* ) |
buf
(私有)
|
引用底层缓冲区的
std::
span
<
CharT
>
类型对象。
( 说明专用成员对象* ) |
成员函数
公有成员函数 |
|
构造
basic_spanbuf
对象
(公有成员函数) |
|
|
(析构函数)
[virtual]
|
销毁
basic_spanbuf
对象
(虚函数公有成员函数) |
赋值
basic_spanbuf
对象
(公有成员函数) |
|
交换两个
basic_spanbuf
对象
(公有成员函数) |
|
|
根据模式获取或初始化底层缓冲区
(公有成员函数) |
|
受保护成员函数 |
|
|
[virtual]
|
尝试用数组替换受控字符序列
(虚函数受保护成员函数) |
|
[virtual]
|
使用相对寻址重新定位输入序列、输出序列或两者中的下一个指针
(虚函数受保护成员函数) |
|
[virtual]
|
使用绝对寻址重新定位输入序列、输出序列或两者中的下一个指针
(虚函数受保护成员函数) |
非成员函数
|
(C++23)
|
特化
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>
的虚保护成员函数)
|
|
返回指向输出区域起始位置、当前字符和末尾的指针
(受保护的成员函数) |
|
|
推进输出序列的下一指针
(受保护的成员函数) |
|
|
重新定位输出序列的起始指针、下一个指针和结束指针
(受保护成员函数) |
|
Putback |
|
|
[virtual]
|
将字符放回输入序列,可能修改输入序列
(
std::basic_streambuf<CharT,Traits>
的虚受保护成员函数)
|
注释
std::basic_spanbuf
不拥有底层缓冲区。
程序员有责任确保当底层缓冲区被
std::basic_spanbuf
对象使用时处于其生命周期内。若多个线程通过不同的
std::basic_spanbuf
对象操作同一底层缓冲区,则可能需要额外的同步机制。
| 功能测试 宏 | 值 | 标准 | 功能特性 |
|---|---|---|---|
__cpp_lib_spanstream
|
202106L
|
(C++23) |
std::spanbuf
,
std::spanstream
|
另请参阅
|
实现原始字符串设备
(类模板) |
|
|
(C++98 中已弃用)
(C++26 中已移除)
|
实现原始字符数组设备
(类) |