[stringstream] # 31 Input/output library [[input.output]](./#input.output) ## 31.8 String-based streams [[string.streams]](string.streams#stringstream) ### 31.8.5 Class template basic_stringstream [stringstream] #### [31.8.5.1](#general) General [[stringstream.general]](stringstream.general) [🔗](#lib:basic_stringstream) namespace std {template, class Allocator = allocator>class basic_stringstream : public basic_iostream {public:using char_type = charT; using int_type = typename traits::int_type; using pos_type = typename traits::pos_type; using off_type = typename traits::off_type; using traits_type = traits; using allocator_type = Allocator; // [[stringstream.cons]](#cons "31.8.5.2 Constructors"), constructors basic_stringstream() : basic_stringstream(ios_base::out | ios_base::in) {}explicit basic_stringstream(ios_base::openmode which); explicit basic_stringstream(const basic_string& s, ios_base::openmode which = ios_base::out | ios_base::in); basic_stringstream(ios_base::openmode which, const Allocator& a); explicit basic_stringstream( basic_string&& s, ios_base::openmode which = ios_base::out | ios_base::in); template basic_stringstream(const basic_string& s, const Allocator& a): basic_stringstream(s, ios_base::out | ios_base::in, a) {}template basic_stringstream(const basic_string& s, ios_base::openmode which, const Allocator& a); templateexplicit basic_stringstream(const basic_string& s, ios_base::openmode which = ios_base::out | ios_base::in); templateexplicit basic_stringstream(const T& t, ios_base::openmode which = ios_base::out | ios_base::in); template basic_stringstream(const T& t, const Allocator& a); template basic_stringstream(const T& t, ios_base::openmode which, const Allocator& a); basic_stringstream(const basic_stringstream&) = delete; basic_stringstream(basic_stringstream&& rhs); basic_stringstream& operator=(const basic_stringstream&) = delete; basic_stringstream& operator=(basic_stringstream&& rhs); // [[stringstream.swap]](#swap "31.8.5.3 Swap"), swapvoid swap(basic_stringstream& rhs); // [[stringstream.members]](#members "31.8.5.4 Member functions"), members basic_stringbuf* rdbuf() const; basic_string str() const &; template basic_string str(const SAlloc& sa) const; basic_string str() &&; basic_string_view view() const noexcept; void str(const basic_string& s); templatevoid str(const basic_string& s); void str(basic_string&& s); templatevoid str(const T& t); private: basic_stringbuf *sb*; // *exposition only*};} [1](#general-1) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9697) The class templatebasic_stringstream supports reading and writing from objects of classbasic_string[.](#general-1.sentence-1) It uses abasic_stringbuf object to control the associated sequence[.](#general-1.sentence-2) For the sake of exposition, the maintained data is presented here as - [(1.1)](#general-1.1) *sb*, the stringbuf object[.](#general-1.sentence-3) #### [31.8.5.2](#cons) Constructors [[stringstream.cons]](stringstream.cons) [🔗](#lib:basic_stringstream,constructor) `explicit basic_stringstream(ios_base::openmode which); ` [1](#cons-1) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9720) *Effects*: Initializes the base class withbasic_iostream(addressof(*sb*)) ([[iostream.cons]](iostream.cons "31.7.5.7.2 Constructors")) and*sb* withbasic_stringbuf(which)[.](#cons-1.sentence-1) [🔗](#lib:basic_stringstream,constructor_) `explicit basic_stringstream( const basic_string& s, ios_base::openmode which = ios_base::out | ios_base::in); ` [2](#cons-2) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9738) *Effects*: Initializes the base class withbasic_iostream(addressof(*sb*)) ([[iostream.cons]](iostream.cons "31.7.5.7.2 Constructors")) and*sb* withbasic_stringbuf(s, which)[.](#cons-2.sentence-1) [🔗](#lib:basic_stringstream,constructor__) `basic_stringstream(ios_base::openmode which, const Allocator& a); ` [3](#cons-3) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9754) *Effects*: Initializes the base class withbasic_iostream(addressof(*sb*)) ([[iostream.cons]](iostream.cons "31.7.5.7.2 Constructors")) and *sb* withbasic_stringbuf(which, a) ([[stringbuf.cons]](stringbuf.cons "31.8.2.2 Constructors"))[.](#cons-3.sentence-1) [🔗](#lib:basic_stringstream,constructor___) `explicit basic_stringstream( basic_string&& s, ios_base::openmode which = ios_base::out | ios_base::in); ` [4](#cons-4) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9770) *Effects*: Initializes the base class withbasic_iostream(addressof(*sb*)) ([[iostream.cons]](iostream.cons "31.7.5.7.2 Constructors")) and *sb* withbasic_stringbuf(std​::​move(s), which) ([[stringbuf.cons]](stringbuf.cons "31.8.2.2 Constructors"))[.](#cons-4.sentence-1) [🔗](#lib:basic_stringstream,constructor____) `template basic_stringstream( const basic_string& s, ios_base::openmode which, const Allocator& a); ` [5](#cons-5) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9787) *Effects*: Initializes the base class withbasic_iostream(addressof(*sb*)) ([[iostream.cons]](iostream.cons "31.7.5.7.2 Constructors")) and *sb* withbasic_stringbuf(s, which, a) ([[stringbuf.cons]](stringbuf.cons "31.8.2.2 Constructors"))[.](#cons-5.sentence-1) [🔗](#lib:basic_stringstream,constructor_____) `template explicit basic_stringstream( const basic_string& s, ios_base::openmode which = ios_base::out | ios_base::in); ` [6](#cons-6) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9804) *Constraints*: is_same_v is false[.](#cons-6.sentence-1) [7](#cons-7) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9808) *Effects*: Initializes the base class withbasic_iostream(addressof(*sb*)) ([[iostream.cons]](iostream.cons "31.7.5.7.2 Constructors")) and *sb* withbasic_stringbuf(s, which) ([[stringbuf.cons]](stringbuf.cons "31.8.2.2 Constructors"))[.](#cons-7.sentence-1) [🔗](#lib:basic_stringstream,constructor______) `template explicit basic_stringstream(const T& t, ios_base::openmode which = ios_base::out | ios_base::in); template basic_stringstream(const T& t, const Allocator& a); template basic_stringstream(const T& t, ios_base::openmode which, const Allocator& a); ` [8](#cons-8) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9827) Let which be ios_base​::​out | ios_base​::​in for the overload with no parameter which, anda be Allocator() for the overload with no parameter a[.](#cons-8.sentence-1) [9](#cons-9) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9832) *Constraints*: is_convertible_v> is true[.](#cons-9.sentence-1) [10](#cons-10) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9837) *Effects*: Initializes the base class with addressof(*sb*), and direct-non-list-initializes *sb* with t, which, a[.](#cons-10.sentence-1) [🔗](#lib:basic_stringstream,constructor_______) `basic_stringstream(basic_stringstream&& rhs); ` [11](#cons-11) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9849) *Effects*: Move constructs from the rvalue rhs[.](#cons-11.sentence-1) This is accomplished by move constructing the base class, and the containedbasic_stringbuf[.](#cons-11.sentence-2) Then calls basic_istream​::​set_rdbuf(addressof(*sb*)) to install the contained basic_stringbuf[.](#cons-11.sentence-3) #### [31.8.5.3](#swap) Swap [[stringstream.swap]](stringstream.swap) [🔗](#lib:swap,basic_stringstream) `void swap(basic_stringstream& rhs); ` [1](#swap-1) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9866) *Effects*: Equivalent to:basic_iostream::swap(rhs);*sb*.swap(rhs.*sb*); [🔗](#lib:swap,basic_stringstream_) `template void swap(basic_stringstream& x, basic_stringstream& y); ` [2](#swap-2) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9883) *Effects*: Equivalent to x.swap(y)[.](#swap-2.sentence-1) #### [31.8.5.4](#members) Member functions [[stringstream.members]](stringstream.members) [🔗](#lib:rdbuf,basic_stringstream) `basic_stringbuf* rdbuf() const; ` [1](#members-1) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9896) *Returns*: const_cast*>(addressof(*sb*))[.](#members-1.sentence-1) [🔗](#lib:str,basic_stringstream) `basic_string str() const &; ` [2](#members-2) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9907) *Effects*: Equivalent to: return rdbuf()->str(); [🔗](#lib:str,basic_stringstream_) `template basic_string str(const SAlloc& sa) const; ` [3](#members-3) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9919) *Effects*: Equivalent to: return rdbuf()->str(sa); [🔗](#lib:str,basic_stringstream__) `basic_string str() &&; ` [4](#members-4) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9930) *Effects*: Equivalent to: return std​::​move(*rdbuf()).str(); [🔗](#lib:view,basic_stringstream) `basic_string_view view() const noexcept; ` [5](#members-5) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9941) *Effects*: Equivalent to: return rdbuf()->view(); [🔗](#lib:str,basic_stringstream___) `void str(const basic_string& s); ` [6](#members-6) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9952) *Effects*: Equivalent to: rdbuf()->str(s); [🔗](#lib:str,basic_stringstream____) `template void str(const basic_string& s); ` [7](#members-7) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9964) *Effects*: Equivalent to: rdbuf()->str(s); [🔗](#lib:str,basic_stringstream_____) `void str(basic_string&& s); ` [8](#members-8) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9975) *Effects*: Equivalent to: rdbuf()->str(std​::​move(s)); [🔗](#lib:str,basic_stringstream______) `template void str(const T& t); ` [9](#members-9) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9987) *Constraints*: is_convertible_v> is true[.](#members-9.sentence-1) [10](#members-10) [#](http://github.com/Eelis/draft/tree/9adde4bc1c62ec234483e63ea3b70a59724c745a/source/iostreams.tex#L9992) *Effects*: Equivalent to: rdbuf()->str(t);