std::basic_ospanstream<CharT,Traits>::span

来自cppreference.com

std::span<CharT> span() const noexcept;
(1) (C++23 起)
void span( std::span<CharT> s ) noexcept;
(2) (C++23 起)
1) 若包装的 std::basic_spanbuf 的打开模式中设置了 std::ios_base::out,则获取引用被写入区域的 span,否则获取引用底层缓冲区的 span
2) 使其所包装的 std::basic_spanbuf 进行 s 所引用的缓冲区上的 I/O 。

参数

s - 引用要用作流的新底层缓冲区的 std::span

返回值

1) 引用底层缓冲区或已写入区域的 std::span,取决于其所包装的 std::basic_spanbuf 的打开模式。
2) (无)

示例

#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]

参阅

(C++23)
根据模式获得或初始化底层缓冲区
(std::basic_spanbuf<CharT,Traits> 的公开成员函数)