std::basic_ostream<CharT,Traits>::flush

basic_ostream& flush();

Writes uncommitted changes to the underlying output sequence.

If rdbuf() is a null pointer, does nothing.

Otherwise, behaves as an UnformattedOutputFunction (since C++11). After constructing and checking the sentry object, calls rdbuf()->pubsync(). If the call returns -1, calls setstate(badbit).

Parameters

(none).

Return value

*this.

Exceptions

May throw std::ios_base::failure if exceptions()&badbit!=0.

Example

#include <thread>
#include <iostream>
#include <chrono>
void f()
{
    std::cout << "Output from thread...";
    std::this_thread::sleep_for(std::chrono::seconds(2));
    std::cout << "...thread calls flush()\n";
    std::cout.flush();
}
 
int main()
{
    std::thread t1(f);
    std::this_thread::sleep_for(std::chrono::seconds(1));
    std::clog << "Output from main\n";
    t1.join();
}

Output:

Output from main
Output from thread.....thread calls flush()

See also

synchronizes with the underlying storage device
(public member function of std::basic_istream<CharT,Traits>)
flushes the output stream
(function template)
outputs '\n' and flushes the output stream
(function template)

© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
http://en.cppreference.com/w/cpp/io/basic_ostream/flush