std::basic_filebuf<CharT,Traits>:: operator=
From cppreference.com
<
cpp
|
io
|
basic filebuf
std::
basic_filebuf
&
operator
=
(
std::
basic_filebuf
&&
rhs
)
;
|
(1) | (since C++11) |
std::
basic_filebuf
&
operator
=
(
const
std::
basic_filebuf
&
rhs
)
=
delete
;
|
(2) | |
Assigns another
basic_filebuf
object.
1)
First calls
close()
to close the associated file, then moves the contents of
rhs
into
*
this
: the put and get buffers, the associated file, the locale, the openmode, the is_open flag, and any other state. After the move,
rhs
is not associated with a file and
rhs.
is_open
(
)
==
false
.
Parameters
rhs | - |
another
basic_filebuf
that will be moved from
|
Return value
* this
Example
Run this code
#include <cassert> #include <fstream> #include <iostream> #include <string> int main() { std::ofstream{"test.in"} << "test\n"; // writes via a temporary object std::ifstream fin("test.in"); // read-only stream std::ofstream fout("test.out"); // write-only stream std::string s; std::getline(fin, s); std::cout << "s = [" << s << "]\n"; // s contains "test" assert(fout.is_open()); *fin.rdbuf() = std::move(*fout.rdbuf()); assert(!fout.is_open()); std::getline(fin, s); std::cout << "s = [" << s << "]\n"; // s is empty input }
Output:
s = [test] s = []
See also
constructs a
basic_filebuf
object
(public member function) |
|
(C++11)
|
swaps two
basic_filebuf
objects
(public member function) |