std::basic_istream<CharT,Traits>:: swap
I/O manipulators | ||||
Print functions (C++23) | ||||
C-style I/O | ||||
Buffers | ||||
(C++23)
|
||||
(
C++98/26*
)
|
||||
(C++20)
|
||||
Streams | ||||
Abstractions | ||||
File I/O | ||||
String I/O | ||||
Array I/O | ||||
(C++23)
|
||||
(C++23)
|
||||
(C++23)
|
||||
(
C++98/26*
)
|
||||
(
C++98/26*
)
|
||||
(
C++98/26*
)
|
||||
Synchronized Output | ||||
(C++20)
|
||||
Types | ||||
Error category interface | ||||
(C++11)
|
||||
(C++11)
|
Global objects | ||||
Member functions | ||||
(C++11)
|
||||
Formatted input | ||||
Unformatted input | ||||
Positioning | ||||
Miscellaneous | ||||
basic_istream::swap
(C++11)
|
||||
Member classes | ||||
Non-member functions | ||||
protected
:
void swap ( basic_istream & rhs ) ; |
(since C++11) | |
Calls
basic_ios
::
swap
(
rhs
)
to swap all data members of the base class except for
rdbuf()
, and swaps the values of the
gcount()
counters between
*
this
and
rhs
. This swap function is protected: it is called by the swap functions of the swappable input stream classes
std::basic_ifstream
and
std::basic_istringstream
, which know how to correctly swap the associated streambuffers.
Parameters
rhs | - |
different
basic_istream
object of the same type to swap with
|
Example
#include <iostream> #include <sstream> #include <utility> int main() { std::istringstream s1("hello"); std::istringstream s2("bye"); s1.swap(s2); // OK, istringstream has a public swap() std::swap(s1, s2); // OK, calls s1.swap(s2) // std::cin.swap(s2); // ERROR: swap is a protected member std::cout << s1.rdbuf() << '\n'; }
Output:
hello