Namensräume
Varianten
Aktionen

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

Von cppreference.com
 
 
 
std::basic_ispanstream
Memberfunktionen
Operationen auf dem zugrundeliegenden Puffer
basic_ispanstream::span
(C++23)
Nicht-Member-Funktionen
 
std::span<const CharT> span() const noexcept;
(1) (seit C++23)
void span(std::span<CharT> s) noexcept;
(2) (seit C++23)
template< class SpanLike >
void span( SpanLike&& r ) noexcept;
(3) (seit C++23)
1) Ruft einen span ab, der auf den geschriebenen Bereich verweist, wenn std::ios_base::out im Öffnungsmodus des umschlossenen std::basic_spanbuf gesetzt ist, oder einen span, der auf den zugrunde liegenden Puffer verweist, andernfalls.
2) Veranlasst den umschlossenen std::basic_spanbuf, E/A auf dem von s referenzierten Puffer durchzuführen.
3) Dasselbe wie (2), außer dass s wie folgt erhalten wird:
std::span<const CharT> cs{std::forward<SpanLike>(r)};
std::span<CharT> s{const_cast<CharT*>(cs.data()), cs.size()};

. Diese Überladung nimmt nur an der Überladungsauflösung teil, wenn SpanLike borrowed_range modelliert, std::convertible_to<SpanLike, std::span<CharT>> ist false und std::convertible_to<SpanLike, std::span<const CharT>> ist true.

Inhalt

[bearbeiten] Parameter

s - std::span, das den Speicherbereich referenziert, der als neuer zugrunde liegender Puffer des Streams verwendet werden soll
r - borrowed_range, der als neuer zugrunde liegender Puffer des Streams verwendet werden soll

[bearbeiten] Rückgabewert

1) Ein std::span, der auf den zugrunde liegenden Puffer oder den geschriebenen Bereich verweist, abhängig vom Öffnungsmodus des umschlossenen std::basic_spanbuf.
2,3) (keiner)

[bearbeiten] Beispiel

#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'; // note explicit null-termination
    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 uses out_buf as internal storage, no allocations
    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; // buffer is exhausted
    assert(!ist);
}

Ausgabe

sp.data(): [C++ 23]
out_buf: [C++ 23]

[bearbeiten] Siehe auch

ruft einen zugrunde liegenden Puffer ab oder initialisiert ihn gemäß dem Modus
(public member function of std::basic_spanbuf<CharT,Traits>) [bearbeiten]