std::basic_ispanstream<CharT,Traits>:: span
From cppreference.net
<
cpp
|
io
|
basic ispanstream
|
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)
と同様であるが、
s
は以下のようにして取得される:
std:: span < const CharT > cs { std:: forward < SpanLike > ( r ) } ;
std:: span < CharT > s { const_cast < CharT * > ( cs. data ( ) ) , cs. size ( ) } ;
。このオーバーロードは、
std:: span < const CharT > cs { std:: forward < SpanLike > ( r ) } ;
std:: span < CharT > s { const_cast < CharT * > ( cs. data ( ) ) , cs. size ( ) } ;
。このオーバーロードは、
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>
の公開メンバー関数)
|