std::basic_ispanstream<CharT,Traits>::span
来自cppreference.com
<tbody>
</tbody>
std::span<const CharT> span() const noexcept; |
(1) | (C++23 起) |
void span( std::span<CharT> s ) noexcept; |
(2) | (C++23 起) |
template< class SpanLike > void span( SpanLike&& r ) noexcept; |
(3) | (C++23 起) |
1) 若包装的 std::basic_spanbuf 的打开模式中设置了 std::ios_base::out,则获取引用被写入区域的
span,否则获取引用底层缓冲区的 span。2) 使其所包装的 std::basic_spanbuf 进行
s 所引用的缓冲区上的 I/O 。3) 同 (2),但如同通过
获得
std::span<const CharT> cs{std::forward<SpanLike>(r)}; std::span<CharT> s{const_cast<CharT*>(cs.data()), cs.size()};获得
s。此重载只有在 SpanLike 实现 borrowed_range,std::convertible_to<SpanLike, std::span<CharT>> 为 false,且 std::convertible_to<SpanLike, std::span<const CharT>> 为 true 时才会参与重载决议。
参数
| s | - | 引用要用作流的新底层缓冲区的 std::span |
| r | - | 要用做流的新底层缓冲区的 borrowed_range
|
返回值
1) 引用底层缓冲区或已写入区域的 std::span,取决于其所包装的 std::basic_spanbuf 的打开模式。
2,3) (无)
示例
运行此代码
#include <cassert>
#include <iostream>
#include <span>
#include <spanstream>
int main()
{
char out_buf[16];
std::ospanstream ost{std::span<char>{out_buf}};
ost << "C++" << ' ' << 23 << '\0'; // 注意显式的空终止
auto sp = ost.span();
assert(
sp[0] == 'C' && sp[1] == '+' && sp[2] == '+' &&
sp[3] == ' ' && sp[4] == '2' && sp[5] == '3' &&
sp[6] == '\0'
);
std::cout << "sp.data(): [" << sp.data() << "]\n";
std::cout << "out_buf: [" << out_buf << "]\n";
// spanstream 使用 out_buf 为内部存储,不进行分配
assert(static_cast<char*>(out_buf) == sp.data());
const char in_buf[] = "X Y 42";
std::ispanstream ist{std::span<const char>{in_buf}};
assert(static_cast<const char*>(in_buf) == ist.span().data());
char c;
ist >> c;
assert(c == 'X');
ist >> c;
assert(c == 'Y');
int i;
ist >> i;
assert(i == 42);
ist >> i; // 缓冲区已耗尽
assert(!ist);
}
输出:
sp.data(): [C++ 23]
out_buf: [C++ 23]
参阅
| 根据模式获得或初始化底层缓冲区 ( std::basic_spanbuf<CharT,Traits> 的公开成员函数)
|