std::basic_stringstream<CharT,Traits,Allocator>:: basic_stringstream
| (1) | ||
|
explicit
basic_stringstream
(
std::
ios_base
::
openmode
mode
=
std:: ios_base :: in | std:: ios_base :: out ) ; |
(до C++11) | |
|
explicit
basic_stringstream
(
std::
ios_base
::
openmode
mode
)
;
|
(начиная с C++11) | |
|
basic_stringstream
(
)
: basic_stringstream ( std:: ios_base :: in | std:: ios_base :: out ) { } |
(2) | (начиная с C++11) |
|
explicit
basic_stringstream
(
const
std::
basic_string
<
CharT, Traits, Allocator
>
&
str,
|
(3) | |
|
explicit
basic_stringstream
(
std::
basic_string
<
CharT, Traits, Allocator
>
&&
str,
|
(4) | (начиная с C++20) |
|
basic_stringstream
(
std::
ios_base
::
openmode
mode,
const
Allocator
&
a
)
;
|
(5) | (начиная с C++20) |
|
template
<
class
SAlloc
>
basic_stringstream
(
const
std::
basic_string
<
CharT, Traits, SAlloc
>
&
str,
|
(6) | (начиная с C++20) |
|
template
<
class
SAlloc
>
basic_stringstream
(
const
std::
basic_string
<
CharT, Traits, SAlloc
>
&
str,
|
(7) | (начиная с C++20) |
|
template
<
class
SAlloc
>
explicit
basic_stringstream
|
(8) | (начиная с C++20) |
|
template
<
class
StringViewLike
>
explicit
basic_stringstream
|
(9) | (начиная с C++26) |
|
template
<
class
StringViewLike
>
basic_stringstream
(
const
StringViewLike
&
t,
|
(10) | (начиная с C++26) |
|
template
<
class
StringViewLike
>
basic_stringstream ( const StringViewLike & t, const Allocator & a ) ; |
(11) | (начиная с C++26) |
|
basic_stringstream
(
basic_stringstream
&&
other
)
;
|
(12) | (начиная с C++11) |
Создает новый строковый поток.
Дано
-
base_typeкак std:: basic_iostream < CharT, Traits > , и -
buf_typeкак std:: basic_stringbuf < CharT, Traits, Allocator > ,
std::basic_iostream
база и
демонстрационный элемент данных
sb
инициализируются следующим образом.
|
Перегрузка
конструкторов |
std::basic_iostream база |
sb
|
|---|---|---|
| (1) | base_type ( std:: addressof ( sb ) ) [1] | buf_type ( mode ) |
| (2) | buf_type ( std:: ios_base :: in | std:: ios_base :: out ) | |
| (3) | buf_type ( str, mode ) | |
| (4) | buf_type ( std :: move ( str ) , mode ) | |
| (5) | buf_type ( mode, a ) | |
| (6) | buf_type ( str, mode, a ) | |
| (7) | buf_type ( str, std:: ios_base :: in | std:: ios_base :: out , a ) | |
| (8) | buf_type ( str, mode ) | |
| (9) | std:: addressof ( sb ) | { t, mode, Allocator ( ) } |
| (10) | { t, mode, a } | |
| (11) | { t, std:: ios_base :: in | std:: ios_base :: out , a } | |
| (12) | перемещающий конструктор из other 's std::basic_iostream базы | перемещающий конструктор из other. sb |
- ↑ Базовый класс std::basic_iostream инициализировался с помощью base_type ( & sb ) (для перегрузок (1,3) ) до C++11.
Содержание |
Параметры
| str | - | строка для использования в качестве начального содержимого строкового потока | ||||||||||||||||
| t | - | объект (преобразуемый в std::basic_string_view ) для использования в качестве начального содержимого строкового потока | ||||||||||||||||
| a | - | аллокатор, используемый для выделения памяти под содержимое строкового потока | ||||||||||||||||
| mode | - |
определяет режим открытия потока. Это
BitmaskType
, определены следующие константы:
|
||||||||||||||||
| other | - | другой строковый поток для использования в качестве источника |
Примечания
Создание одноразовых объектов
basic_stringstream
в тесном цикле, например при использовании для преобразования строк, может быть значительно более затратным, чем вызов
str()
для повторного использования того же объекта.
| Feature-test macro | Value | Std | Feature |
|---|---|---|---|
__cpp_lib_sstream_from_string_view
|
202306L
|
(C++26) | Интерфейс между std::stringstream и std::string_view , ( 9-11 ) |
Пример
#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'; // выходной поток в режиме добавления (C++11) std::ostringstream buf2("test", std::ios_base::ate); buf2 << '1'; std::cout << buf2.str() << '\n'; }
Вывод:
buf1 = 7 n = 7 n = -10 test1
Отчеты о дефектах
Следующие отчеты об изменениях поведения, влияющие на дефекты, были применены ретроактивно к ранее опубликованным стандартам C++.
| DR | Applied to | Behavior as published | Correct behavior |
|---|---|---|---|
| P0935R0 | C++11 | конструктор по умолчанию был explicit | сделан implicit |
Смотрите также
|
получает или устанавливает содержимое базового строкового устройства
(публичная функция-член) |
|
создаёт объект
basic_stringbuf
(публичная функция-член
std::basic_stringbuf<CharT,Traits,Allocator>
)
|