std::basic_streambuf<CharT,Traits>::underflow
来自 cppreference.com
< cpp | io | basic streambuf
protected: virtual int_type underflow(); |
||
确保输入区域中至少有一个字符可用,方法是更新指向输入区域的指针(如果需要),并在需要时从输入序列中读取更多数据。如果成功,则返回该字符的值(使用 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] |
从关联的文件读取 (virtual protected member function of std::basic_filebuf<CharT,Traits> ) |
[virtual] |
返回输入序列中可用的下一个字符 (virtual protected member function of std::basic_stringbuf<CharT,Traits,Allocator> ) |
[virtual] |
从输入序列中读取一个字符,但不前进下一个指针 (virtual protected member function of std::strstreambuf ) |