std::basic_syncbuf
来自 cppreference.cn
在头文件 <syncstream> 中定义 |
||
template< class CharT, |
(since C++20) | |
std::basic_syncbuf
是 std::basic_streambuf 的包装器(在构造时作为指针提供)。它在其内部缓冲区中累积输出,并在销毁时以及显式请求时原子地将其全部内容传输到被包装的缓冲区,以便它们显示为连续的字符序列。它保证只要对同一缓冲区的所有其他输出都是通过可能不同的 std::basic_syncbuf
实例进行的,就不会发生数据竞争,也不会发生发送到被包装缓冲区的字符的交错。
std::basic_syncbuf
的典型实现包含指向被包装的 std::basic_streambuf 的指针、一个布尔标志,指示缓冲区是否会在同步(刷新)时将其内容传输到被包装的缓冲区、一个布尔标志,指示当策略是不在同步时发射时,是否存在待处理的刷新、一个使用 Allocator
的内部缓冲区(例如 std::string),以及一个指向互斥锁的指针,该互斥锁用于同步访问同一被包装流缓冲区的多个线程之间的发射(这些互斥锁可能位于哈希映射中,其中指向 std::basic_streambuf 对象的指针用作键)。
与其他 streambuf 类一样,std::basic_syncbuf
通常仅通过相应的流 std::osyncstream 访问,而不是直接访问。
提供了几种常见字符类型的 typedef
在头文件
<syncstream> 中定义 | |
类型 | 定义 |
std::syncbuf
|
std::basic_syncbuf<char> |
std::wsyncbuf
|
std::basic_syncbuf<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
|
streambuf_type
|
std::basic_streambuf<CharT, Traits> |
[编辑] 成员函数
公共成员函数 | |
构造一个 basic_syncbuf 对象(公共成员函数) | |
赋值一个 basic_syncbuf 对象(公共成员函数) | |
交换两个 basic_syncbuf 对象(公共成员函数) | |
销毁 basic_syncbuf 并发射其内部缓冲区(公共成员函数) | |
原子地将被包装的 streambuf 的整个内部缓冲区传输过去 (公共成员函数) | |
检索被包装的 streambuf 指针 (公共成员函数) | |
检索此 basic_syncbuf 使用的分配器(公共成员函数) | |
更改当前的同步时发射策略 (公共成员函数) | |
受保护成员函数 | |
根据当前的同步时发射策略,发射或记录待处理的刷新 (公共成员函数) |
[编辑] 非成员函数
特化 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 区域 | |
获取 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 区域 | |
将一个字符写入 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> 的虚受保护成员函数) |
Get 区域 | |
[虚函数] |
获取关联的输入序列中可用于输入的字符数(如果已知) ( std::basic_streambuf<CharT,Traits> 的虚受保护成员函数) |
[虚函数] |
从关联的输入序列读取字符到 get 区域 ( std::basic_streambuf<CharT,Traits> 的虚受保护成员函数) |
[虚函数] |
从关联的输入序列读取字符到 get 区域并推进下一个指针 ( std::basic_streambuf<CharT,Traits> 的虚受保护成员函数) |
[虚函数] |
从输入序列读取多个字符 ( std::basic_streambuf<CharT,Traits> 的虚受保护成员函数) |
返回指向 get 区域的开始、当前字符和结尾的指针 (受保护成员函数) | |
推进输入序列中的下一个指针 (受保护成员函数) | |
重新定位输入序列的开始、下一个和结束指针 (受保护成员函数) | |
Put 区域 | |
[虚函数] |
将多个字符写入输出序列 ( std::basic_streambuf<CharT,Traits> 的虚受保护成员函数) |
[虚函数] |
将字符从 put 区域写入关联的输出序列 ( std::basic_streambuf<CharT,Traits> 的虚受保护成员函数) |
返回指向 put 区域的开始、当前字符和结尾的指针 (受保护成员函数) | |
推进输出序列的下一个指针 (受保护成员函数) | |
重新定位输出序列的开始、下一个和结束指针 (受保护成员函数) | |
放回 | |
[虚函数] |
将字符放回到输入序列中,可能会修改输入序列 ( std::basic_streambuf<CharT,Traits> 的虚受保护成员函数) |
[编辑] 注释
特性测试 宏 | 值 | Std | 特性 |
---|---|---|---|
__cpp_lib_syncbuf |
201803L |
(C++20) | 同步缓冲 ostream (std::syncbuf , std::osyncstream) 和操纵符 |