std::basic_osyncstream<CharT,Traits,Allocator>::emit
void emit(); |
Emits all buffered output and executes any pending flushes, by calling emit() on the underlying std::basic_syncbuf.
Parameters
(none).
Example
#include <syncstream>
#include <iostream>
int main()
{
{
std::osyncstream bout(std::cout);
std::bout << "Hello," << '\n'; // no flush
std::bout.emit(); // characters transferred; cout not flushed
std::bout << "World!" << std::endl; // flush noted; cout not flushed
std::bout.emit(); // characters transferred; cout flushed
std::bout << "Greetings." << '\n'; // no flush
} // destructor calls emit(): characters transferred; cout not flushed
// emit can be used for local exception-handling on the wrapped stream
std::osyncstream bout(std::cout);
bout << "Hello, " << "World!" << '\n';
try {
bout.emit();
} catch (...) {
// handle exceptions
}
}Output:
Hello, World! Greetings. Hello, World!
See also
| destroys the basic_osyncstream and emits its internal buffer (public member function) |
|
| atomically transmits the entire internal buffer to the wrapped streambuf (public member function of std::basic_syncbuf<CharT,Traits,Allocator>) |
© cppreference.com
Licensed under the Creative Commons Attribution-ShareAlike Unported License v3.0.
http://en.cppreference.com/w/cpp/io/basic_osyncstream/emit