定义于头文件 <sstream>
template< class CharT, |
std::basic_stringbuf
是关联字符序列为内存常驻的任意字符序列的 std::basic_streambuf 。能从 std::basic_string 的实例初始化它,或将它做成该类的实例。
std::basic_stringbuf
的典型实现保有一个 std::basic_string 类型对象,或等价的可伸缩序列容器作为数据成员,并将它同时用作受控制字符序列(为 std::basic_streambuf 的六个指针所指向的数组)和关联字符序列(所有输入操作的字符源和输出操作的目标)。
另外,典型的实现保有一个 std::ios_base::openmode 类型的数据成员,以指示流的状态(只读、只写、读写、尾端写等)。
若 overflow() 使用过分配策略,则可存储另外的高水位指针,以跟踪最后初始化的字符。 | (C++11 起) |
亦提供二个对常用字符类型的特化:
类型 | 定义 |
stringbuf | basic_stringbuf<char> |
wstringbuf | basic_stringbuf<wchar_t> |
受保护成员函数
试图以数组替换受控字符序列
std::basic_stringbuf<CharT,Traits,Allocator>::setbuf
protected: |
若 s
为空指针且 n
为零,则此函数无效果。
否则,效果是实现定义的:一些实现不做任何事,而一些实现清空当前用作缓冲区的 std::string 成员,并开始以用户提供的大小为 n
,首元素为 s
所指向的字符数组,为输入/输出字符序列的缓冲区。
此函数为受保护虚,仅可通过 pubsetbuf()
或导出自 std::basic_stringbuf
的用户定义类的成员函数调用它。
参数
s | - | 指向用户提供缓冲区首个 CharT 的指针或空指针 |
n | - | 用户提供缓冲区中的 CharT 元素数或零 |
返回值
this 。
注意
弃用的流缓冲 std::strstreambuf 或 boost.IOStreams 设备 boost::basic_array 可用于以可移植方式实现用户提供的字符数组上的 I/O 缓冲。
调用示例
#include <sstream>
#include <string>
#include <iostream>
int main()
{
std::stringbuf sbuf;
char c[1024] = {};
sbuf.pubsetbuf(c, 1024);
std::iostream stream(&sbuf);
stream << 3.14 << std::endl;
std::cout << c << std::endl;
return 0;
}
输出
用相对寻址,重定位输入序列、输出序列或两者中的下一位置指针
std::basic_stringbuf<CharT,Traits,Allocator>::seekoff
protected: virtual pos_type seekoff(off_type off, |
若可能,则重寻位 std::basic_streambuf::gptr 和/或 std::basic_streambuf::pptr 到对应距流的获取和/或放置区起始、结尾或当前位置准确 off
个字符的位置。
- 若
which
包含ios_base::in
而此缓冲为读取打开(即 ((which & ios_base::in) == ios_base::in ),则重寻位获取区内的读指针 std::basic_streambuf::gptr 如后述 - 若
which
包含ios_base::out
而此缓冲为写入打开(即 (which & ios_base::out) == ios_base::out ),则重寻位放置区内的写指针 std::basic_streambuf::pptr 如后述 - 若
which
包含ios_base::in
和ios_base::out
两者而缓冲为读和写打开( (which & (ios_base::in|ios_base::out)) ==(ios_base::in|ios_base::out) )而dir
为 ios_base::beg 或 ios_base::end 之一,则重寻位读和写指针如后述。 - 否则,此函数失败。
若重寻位( gptr
或 pptr
或两者),则按下列方式进行:
1) 若要重寻位的指针为空指针且新偏移 newoff
会为非零,则函数失败。
2) 确定 off_type
类型的新指针偏移 newoff
a) 若 dir == ios_base::beg ,则 newoff
为零
b) 若 dir == ios_base::cur ,则 newoff
为指针的当前位置( gptr()-eback() 或 pptr()-pbase() )
c) 若 dir == ios_base::end ,则 newoff
为缓冲区的整个已初始化部分的长度(若使用过分配,则为高水位指针减起始指针)
3) 若 newoff + off < 0 (重寻位会移动指针到缓冲区的起始指针之前)或若 newoff + off 会指向缓冲区结尾后(或若使用过分配,则为缓冲区中最后未初始化字符之后),则函数失败
4) 否则,如同以 gptr() = eback() + newoff + off 或 pptr() = pbase() + newoff + off 赋值指针。
参数
off | - | 要设置下一位置指针到的相对位置 | ||||||||
dir | - | 定义应用偏移到的基位置。它能为下列常量之一:
| ||||||||
which | - | 定义影响的是输入序列、输出序列还是两者。它能为下列常量之一或其组合:
|
返回值
成功时为 pos_type(newoff) ,失败时或若 pos_type 不能表示结果流位置则为 pos_type(off_type(-1)) 。
调用示例
#include <sstream>
#include <string>
#include <iostream>
// typedef basic_stringbuf<char> stringbuf;
struct mybuf : std::stringbuf
{
mybuf(const std::string& new_str,
std::ios_base::openmode which =
std::ios_base::in | std::ios_base::out)
: std::stringbuf(new_str, which) {}
pos_type tellp()
{
char ch = *pptr();
return ch;
}
pos_type tellg()
{
char ch = *gptr();
return ch;
}
};
int main()
{
mybuf sbuf("123"); // 入/出
std::cout << "put pos = " << sbuf.tellp()
<< " get pos = " << sbuf.tellg() << std::endl;
// 两个指针绝对寻位
sbuf.pubseekoff(1, std::ios_base::beg); // 都前移 1
std::cout << "put pos = " << sbuf.tellp()
<< " get pos = " << sbuf.tellg() << std::endl;
// 试图从当前位置前移两个指针 1
if (-1 == sbuf.pubseekoff(1, std::ios_base::cur))
{
std::cout << "moving both pointers from current position failed\n";
}
std::cout << "put pos = " << sbuf.tellp()
<< " get pos = " << sbuf.tellg() << std::endl;
// 前移写指针 1 ,但不前移读指
// can also be called as ss.seekp(1, std::ios_base::cur);
sbuf.pubseekoff(1, std::ios_base::cur, std::ios_base::out);
std::cout << "put pos = " << sbuf.tellp()
<< " get pos = " << sbuf.tellg() << std::endl;
sbuf.sputc('a'); // 写入输出位置
std::cout << "Wrote 'a' at put position, the buffer is now "
<< sbuf.str() << std::endl;
char ch = sbuf.sgetc();
std::cout << "reading at get position gives '"
<< ch << "'" << std::endl;
return 0;
}
输出