std::basic_ispanstream<CharT,Traits>::span
Von cppreference.com
< cpp | io | basic ispanstream
| 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
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
Führen Sie diesen Code aus
#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>) |