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

来自cppreference.com

basic_ostringstream() : basic_ostringstream(ios_base::out) { }
(1) (C++11 起)
(2)
explicit basic_ostringstream( ios_base::openmode mode = ios_base::out );
(C++11 前)
explicit basic_ostringstream( ios_base::openmode mode );
(C++11 起)
explicit basic_ostringstream( const std::basic_string<CharT,Traits,Allocator>& str,
                              ios_base::openmode mode = ios_base::out );
(3)
basic_ostringstream( basic_ostringstream&& other );
(4) (C++11 起)

构造新的字符串流。

1) 默认构造函数。以默认打开模式构造新的底层字符串设备。
2) 构造新的底层字符串设备。以 basic_stringbuf<Char,Traits,Allocator>(mode | ios_base::out) 构造底层 basic_stringbuf 对象。
3)str 的副本为底层字符串设备的初始内容。以 basic_stringbuf<Char,Traits,Allocator>(str, mode | ios_base::out) 构造底层 basic_stringbuf 对象。
4) 移动构造函数。用移动语义,构造拥有 other 的状态的字符串流。

参数

str - 用于初始化字符串流内容的字符串
mode - 指定流打开模式。它是位掩码类型,定义下列常量:
 
常量 解释
app 每次写入前寻位到流结尾
binary 二进制模式打开
in 为读打开
out 为写打开
trunc 在打开时舍弃流的内容
ate 打开后立即寻位到流结尾
other - 用作源的另一字符串流

注意

在短的循环中,例如在用于字符串转换时构造单次使用的 basic_ostringstream 对象,开销可能显著高于调用 str 并复用同一对象。

缺陷报告

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

DR 应用于 出版时的行为 正确行为
P0935R0 C++11 默认构造函数曾为 explicit 使之为隐式

示例

#include <iostream>
#include <sstream>
int main()
{
    // 默认构造函数(输入/输出流)
    std::stringstream buf1;
    buf1 << 7;
    int n = 0;
    buf1 >> n;
    std::cout << "buf1 = " << buf1.str() << " n = " << n << '\n';
 
    // 输入流
    std::istringstream inbuf("-10");
    inbuf >> n;
    std::cout << "n = " << n << '\n';
 
    // 输出流在 append 模式 (C++11)
    std::ostringstream buf2("test", std::ios_base::ate);
    buf2 << '1';
    std::cout << buf2.str() << '\n';
}

输出:

buf1 = 7 n = 7
n = -10
test1

参阅

获取或设置底层字符串设备对象的内容
(公开成员函数)
构造一个 basic_stringbuf 对象
(std::basic_stringbuf<CharT,Traits,Allocator> 的公开成员函数)