std::basic_stringbuf<CharT,Traits,Allocator>::basic_stringbuf

来自cppreference.com
< cpp‎ | io‎ | basic stringbuf
 
 
 
 
(1)
explicit basic_stringbuf( std::ios_base::openmode which =
                              std::ios_base::in | std::ios_base::out );
(C++11 前)
explicit basic_stringbuf( std::ios_base::openmode which );
(C++11 起)
basic_stringbuf()
    : basic_stringbuf( std::ios_base::in | std::ios_base::out ) {}
(2) (C++11 起)
explicit

    basic_stringbuf( const std::basic_string<CharT, Traits, Allocator>& s,
                     std::ios_base::openmode which =

                         std::ios_base::in | std::ios_base::out );
(3)
explicit basic_stringbuf( std::basic_string<CharT, Traits, Allocator>&& s,

                          std::ios_base::openmode which =

                              std::ios_base::in | std::ios_base::out );
(4) (C++20 起)
basic_stringbuf( std::ios_base::openmode which, const Allocator& a );
(5) (C++20 起)
explicit basic_stringbuf( const Allocator& a )
    : basic_stringbuf( std::ios_base::in | std::ios_base::out, a ) {}
(6) (C++20 起)
template< class SAlloc >

explicit basic_stringbuf( const std::basic_string<CharT, Traits, SAlloc>& s,
                          std::ios_base::openmode which =

                              std::ios_base::in | std::ios_base::out );
(7) (C++20 起)
template< class SAlloc >

basic_stringbuf( const std::basic_string<CharT, Traits, SAlloc>& s,

                 std::ios_base::openmode which, const Allocator& a );
(8) (C++20 起)
template< class SAlloc >

basic_stringbuf( const std::basic_string<CharT, Traits, SAlloc>& s,
                 const Allocator& a )

    : basic_stringbuf( s, std::ios_base::in | std::ios_base::out, a ) {}
(9) (C++20 起)
template< class StringViewLike >

explicit basic_stringbuf( const StringViewLike& t,
                          std::ios_base::openmode which =

                              std::ios_base::in | std::ios_base::out );
(10) (C++26 起)
template< class StringViewLike >

basic_stringbuf( const StringViewLike& t,

                 std::ios_base::openmode which, const Allocator& a );
(11) (C++26 起)
template< class StringViewLike >
basic_stringbuf( const StringViewLike& t, const Allocator& a );
(12) (C++26 起)
basic_stringbuf( basic_stringbuf&& rhs );
(13) (C++11 起)
basic_stringbuf( basic_stringbuf&& rhs, const Allocator& a );
(14) (C++20 起)
basic_stringbuf( const basic_stringbuf& rhs ) = delete;
(15) (C++11 起)

std::basic_streambuf 基以及仅用于阐述的数据成员 bufmode 会按以下方式初始化。

在初始化这些子对象后,重载 (3-12) 如同以调用 init_buf_ptrs() 来初始化输入和输出序列。

 重载   std::basic_streambuf 基  buf mode
(1) 默认初始化 由实现定义
(见下文)
which
(2)  std::ios_base::in |
    std::ios_base::out
 
(3) s which
(4) std::move(s)
(5) a
(6)  std::ios_base::in |
    std::ios_base::out
(7) s which
(8) {s, a}
(9)  std::ios_base::in |
    std::ios_base::out
(10) {sv, Allocator()} which
(11) {sv, a}
(12)  std::ios_base::in |
    std::ios_base::out
(13) rhs
(复制构造)
std::move(rhs).str() rhs.mode
(14)  {std::move(rhs).str(), a} 
1,2) 重载 (1) (C++11 前)(2) (C++11 起) 是默认构造函数。由实现定义是否将序列指针(eback()gptr()egptr()pbase()pptr()epptr())初始化为空指针。
5,6) 构造完成时,str.empty()true
7) 此重载只有在std::is_same_v<SAlloc, Allocator>false时才会参与重载决议。
10-12) 如同用 std::basic_string_view<CharT, Traits> sv = t;t 隐式转换到字符串视图 sv ,然后将它用于上面的表格中。
这些重载只有在 std::is_convertible_v<const StringViewLike&,
                      std::basic_string_view<CharT, Traits>>
true 时才会参与重载决议。
13,14) 重载 (13) 是移动构造函数。*this 中的六个序列指针是否会获取 rhs 中这些指针先前拥有的值会由实现定义。
构造完成时,rhs 为空但依然可用,并且
  • rhs_p 作为 rhs 在此次构造前一刻的状态,以下表达式都会求值为 true
  • str() == rhs_p.str()
  • getloc() == rhs_p.getloc()
  • gptr() - eback() == rhs_p.gptr() - rhs_p.eback()
  • egptr() - eback() == rhs_p.egptr() - rhs_p.eback()
  • pptr() - pbase() == rhs_p.pptr() - rhs_p.pbase()
  • epptr() - pbase() == rhs_p.epptr() - rhs_p.pbase()
  • rhs_a 作为 rhs 在此次构造后一刻的状态,以下表达式都会求值为 true
  • !eback() || eback() != rhs_a.eback()
  • !gptr() || gptr() != rhs_a.gptr()
  • !egptr() || egptr() != rhs_a.egptr()
  • !pbase() || pbase() != rhs_a.pbase()
  • !pptr() || pptr() != rhs_a.pptr()
  • !epptr() || epptr() != rhs_a.epptr()
15) 复制构造函数被删除;std::basic_stringbuf可复制构造 (CopyConstructible)

参数

s - 用于初始化缓冲区的 std::basic_string
t - 用于初始化缓冲区的对象(可转换到 std::basic_string_view
a - 用于构造内部 std::basic_string 的另一分配器
rhs - 另一 basic_stringbuf
which - 指定流打开模式。它是位掩码类型,定义下列常量:
常量 解释
app 每次写入前寻位到流结尾
binary 二进制模式打开
in 为读打开
out 为写打开
trunc 在打开时舍弃流的内容
ate 打开后立即寻位到流结尾
noreplace (C++23) 以独占模式打开

注解

常由 std::basic_stringstream 的构造函数调用。

std::ios_base::instd::ios_base::out 以外的打开模式支持级别在实现中各有不同。C++11 显式指定 str() 中和此构造函数中支持 std::ios_base::ate,但 std::ios_base::appstd::ios_base::truncstd::ios_base::binary 在不同实现上有不同效果。

功能特性测试 标准 功能特性
__cpp_lib_sstream_from_string_view 202306L (C++26) 字符串流的 std::string_view 接口

示例

演示直接调用 basic_stringbuf 的构造函数。

#include <iostream>
#include <sstream>
 
int main()
{
    // 默认构造函数(mode = in | out)
    std::stringbuf buf1;
    buf1.sputc('1');
    std::cout << &buf1 << '\n';
 
    // 在尾端模式中的字符串构造函数(C++11)
    std::stringbuf buf2("test", std::ios_base::in
                              | std::ios_base::out
                              | std::ios_base::ate);
    buf2.sputc('1');
    std::cout << &buf2 << '\n';
 
    // 后附模式测试(结果在编译器间有别)
    std::stringbuf buf3("test", std::ios_base::in
                              | std::ios_base::out
                              | std::ios_base::app);
    buf3.sputc('1');
    buf3.pubseekpos(1);
    buf3.sputc('2');
    std::cout << &buf3 << '\n';
}

输出:

1
test1
est12 (Sun Studio) 2st1 (GCC)

缺陷报告

下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。

缺陷报告 应用于 出版时的行为 正确行为
LWG 432 C++98 1. 重载 (1) 不会分配数组对象
2. 重载 (3) 没有指定如何初始化输入和输出序列
1. 移除该限制
2. 已指定
LWG 562 C++98 重载 (3)bool(which & std::ios_base::out) == true
时会设置 epptr() 到指向最后一个底层字符的下一位置
epptr() 可以设置到更后面的位置
P0935R0 C++11 默认构造函数是显式的 改成隐式的

参阅

构造字符串流
(std::basic_stringstream<CharT,Traits,Allocator> 的公开成员函数)