std::basic_streambuf<CharT,Traits>::pubsetbuf, std::basic_streambuf<CharT,Traits>::setbuf
来自 cppreference.com
< cpp | io | basic streambuf
public: basic_streambuf<CharT, Traits>* pubsetbuf( char_type* s, std::streamsize n ) |
(1) | |
protected: virtual basic_streambuf<CharT, Traits>* setbuf( char_type* s, std::streamsize n ) |
(2) | |
1) 调用最派生类的 setbuf(s, n)。
2) 此函数的基类版本没有效果。派生类可以覆盖此函数以允许使用用户提供的数组移除或替换受控字符序列(缓冲区),或用于任何其他实现特定目的。
内容 |
[编辑] 参数
s | - | 指向用户提供的缓冲区中第一个 CharT 的指针 |
n | - | 用户提供的缓冲区中 CharT 元素的数量 |
[编辑] 返回值
1) setbuf(s, n) 的返回值。
2) this
[编辑] 示例
提供一个 10k 的缓冲区用于读取。在 Linux 上,可以使用 strace 工具观察实际读取的字节数。
运行此代码
#include <fstream> #include <iostream> #include <string> int main() { int cnt = 0; std::ifstream file; char buf[1024 * 10 + 1]; file.rdbuf()->pubsetbuf(buf, sizeof buf); file.open("/usr/share/dict/words"); for (std::string line; getline(file, line);) ++cnt; std::cout << cnt << '\n'; }
可能的输出
356010
[编辑] 缺陷报告
以下行为更改缺陷报告已追溯应用于之前发布的 C++ 标准。
DR | 应用于 | 已发布的行为 | 正确行为 |
---|---|---|---|
LWG 158 | C++98 | setbuf 的默认行为只指定如果 gptr() 不为空且不等于 egptr() |
指定为无操作 适用于所有情况 |
[编辑] 参见
[虚拟] |
尝试用数组替换受控字符序列 ( std::basic_stringbuf<CharT,Traits,Allocator> 的虚拟受保护成员函数) |
[虚拟] |
提供用户提供的缓冲区或将此文件缓冲区设置为非缓冲区 ( std::basic_filebuf<CharT,Traits> 的虚拟受保护成员函数) |
[虚拟] |
尝试用数组替换受控字符序列 ( std::strstreambuf 的虚拟受保护成员函数) |
设置文件流的缓冲区 (函数) |