std::basic_streambuf<CharT,Traits>::underflow
From cppreference.com
< cpp | io | basic streambuf
| protected: virtual int_type underflow(); |
||
入力領域に少なくとも1文字が利用可能であることを保証します。必要に応じて入力領域へのポインタを更新し、該当する場合は入力シーケンスからさらにデータを読み込みます。成功した場合はその文字の値(Traits::to_int_type(c)でint_typeに変換)を返し、失敗した場合はTraits::eof()を返します。
この関数は、新しくロードされたデータ(もしあれば)の場所を定義するために、gptr、egptr、およびebackポインタを更新する場合があります。失敗した場合、この関数はgptr() == nullptrまたはgptr() == egptrのいずれかを保証します。
基底クラスのバージョンはこの関数は何もしません。派生クラスは、枯渇した場合に取得領域の更新を許可するために、この関数をオーバーライドできます。
目次 |
[編集] パラメータ
(なし)
[編集] 戻り値
呼び出し後の、取得ポインタが指す文字の値(成功時)またはTraits::eof()(それ以外の場合)。
基底クラスのバージョンはこの関数traits::eof()を返します。
[編集] 注記
std::streambufのパブリック関数は、gptr() == nullptrまたはgptr() >= egptr()の場合にのみ、この関数を呼び出します。
[編集] 例
このコードを実行
#include <iostream> #include <sstream> class null_filter_buf : public std::streambuf { std::streambuf* src; char ch; // single-byte buffer protected: int underflow() { traits_type::int_type i; while ((i = src->sbumpc()) == '\0') ; // skip zeroes if (!traits_type::eq_int_type(i, traits_type::eof())) { ch = traits_type::to_char_type(i); setg(&ch, &ch, &ch+1); // make one read position available } return i; } public: null_filter_buf(std::streambuf* buf) : src(buf) { setg(&ch, &ch + 1, &ch + 1); // buffer is initially full } }; void filtered_read(std::istream& in) { std::streambuf* orig = in.rdbuf(); null_filter_buf buf(orig); in.rdbuf(&buf); for (char c; in.get(c);) std::cout << c; in.rdbuf(orig); } int main() { char a[] = "This i\0s \0an e\0\0\0xample"; std::istringstream in(std::string(std::begin(a), std::end(a))); filtered_read(in); }
出力
This is an example
[編集] 関連項目
| [virtual] |
関連付けられた入力シーケンスから取得領域に文字を読み込み、次のポインタを進める (virtual protected member function) |
| [virtual] |
関連付けられた出力シーケンスに、配置領域から文字を書き込む (virtual protected member function) |
| [virtual] |
関連付けられたファイルから読み込みます。 ( std::basic_filebuf<CharT,Traits>の仮想保護メンバー関数) |
| [virtual] |
入力シーケンスで利用可能な次の文字を返す ( std::basic_stringbuf<CharT,Traits,Allocator>の仮想保護メンバー関数) |
| [virtual] |
入力シーケンスから文字を読み取りますが、次のポインタは進めません。 ( std::strstreambufの仮想保護メンバー関数) |