Namespaces
Variants
Views
Actions

Difference between revisions of "cpp/io/basic syncbuf"

From cppreference.com
< cpp‎ | io
(+)
 
m (c++20 tag)
Line 1: Line 1:
 
{{cpp/title|basic_syncbuf}}
 
{{cpp/title|basic_syncbuf}}
 
{{cpp/io/basic_syncbuf/navbar}}
 
{{cpp/io/basic_syncbuf/navbar}}
{{ddcl | header=syncstream | 1=
+
{{ddcl | header=syncstream | since=c++20 | 1=
 
template<  
 
template<  
 
     class CharT,  
 
     class CharT,  

Revision as of 09:07, 13 November 2017

 
 
 
std::basic_syncbuf
 
Defined in header <syncstream>
template<

    class CharT,
    class Traits = std::char_traits<CharT>,
    class Allocator = std::allocator<CharT>

> class basic_syncbuf : public std::basic_streambuf<CharT, Traits>
(since C++20)

std::basic_syncbuf is a wrapper for a std::basic_streambuf (provided at construction time as a pointer). It accumulates output in its own internal buffer, and atomically transmits its entire contents to the wrapped buffer on destruction and when explicitly requested, so that they appear as a contiguous sequence of characters.

Typical implementation of std::basic_syncbuf holds a pointer to the wrapped std::basic_streambuf and a boolean flag indicating whether the buffer will transmit its contents to the wrapped buffer on sync (flush).

Two specializations for common character types are also defined:

Defined in header <sstream>
Type Definition
syncbuf basic_syncbuf<char>
wsyncbuf basic_syncbuf<wchar_t>

Contents

Member types

Member type Definition
char_type CharT[edit]
traits_type Traits; the program is ill-formed if Traits::char_type is not CharT.[edit]
int_type Traits::int_type[edit]
pos_type Traits::pos_type[edit]
off_type Traits::off_type[edit]
allocator_type Allocator
streambuf_type std::basic_streambuf<CharT, Traits>

Member functions

Template:cpp/io/basic synbuf/dsc swapTemplate:cpp/io/basic synbuf/dsc destructorTemplate:cpp/io/basic synbuf/dsc emitTemplate:cpp/io/basic synbuf/dsc get wrappedTemplate:cpp/io/basic synbuf/dsc get allocatorTemplate:cpp/io/basic synbuf/dsc set emit on sync

Public member functions

constructs a basic_syncbuf object
(public member function) [edit]
assigns a basic_syncbuf object
(public member function) [edit]

Protected member functions

either emits, or records a pending flush, depending on the current emit-on-sync policy
(public member function) [edit]

Non-member functions

specializes the std::swap algorithm
(function template) [edit]

Inherited from std::basic_streambuf

Member types

Member type Definition
char_type CharT[edit]
traits_type Traits; the program is ill-formed if Traits::char_type is not CharT.[edit]
int_type Traits::int_type[edit]
pos_type Traits::pos_type[edit]
off_type Traits::off_type[edit]

Member functions

[virtual]
destructs the basic_streambuf object
(virtual public member function of std::basic_streambuf<CharT,Traits>) [edit]
Locales
invokes imbue()
(public member function of std::basic_streambuf<CharT,Traits>) [edit]
obtains a copy of the associated locale
(public member function of std::basic_streambuf<CharT,Traits>) [edit]
Positioning
invokes setbuf()
(public member function of std::basic_streambuf<CharT,Traits>) [edit]
invokes seekoff()
(public member function of std::basic_streambuf<CharT,Traits>) [edit]
invokes seekpos()
(public member function of std::basic_streambuf<CharT,Traits>) [edit]
invokes sync()
(public member function of std::basic_streambuf<CharT,Traits>) [edit]
Get area
obtains the number of characters immediately available in the get area
(public member function of std::basic_streambuf<CharT,Traits>) [edit]
advances the input sequence, then reads one character without advancing again
(public member function of std::basic_streambuf<CharT,Traits>) [edit]
(removed in C++17)
reads one character from the input sequence and advances the sequence
(public member function of std::basic_streambuf<CharT,Traits>) [edit]
reads one character from the input sequence without advancing the sequence
(public member function of std::basic_streambuf<CharT,Traits>) [edit]
invokes xsgetn()
(public member function of std::basic_streambuf<CharT,Traits>) [edit]
Put area
writes one character to the put area and advances the next pointer
(public member function of std::basic_streambuf<CharT,Traits>) [edit]
invokes xsputn()
(public member function of std::basic_streambuf<CharT,Traits>) [edit]
Putback
puts one character back in the input sequence
(public member function of std::basic_streambuf<CharT,Traits>) [edit]
moves the next pointer in the input sequence back by one
(public member function of std::basic_streambuf<CharT,Traits>) [edit]

Protected member functions

constructs a basic_streambuf object
(protected member function) [edit]
(C++11)
replaces a basic_streambuf object
(protected member function) [edit]
(C++11)
swaps two basic_streambuf objects
(protected member function) [edit]
Locales
[virtual]
changes the associated locale
(virtual protected member function of std::basic_streambuf<CharT,Traits>) [edit]
Positioning
[virtual]
replaces the buffer with user-defined array, if permitted
(virtual protected member function of std::basic_streambuf<CharT,Traits>) [edit]
[virtual]
repositions the next pointer in the input sequence, output sequence, or both, using relative addressing
(virtual protected member function of std::basic_streambuf<CharT,Traits>) [edit]
[virtual]
repositions the next pointer in the input sequence, output sequence, or both using absolute addressing
(virtual protected member function of std::basic_streambuf<CharT,Traits>) [edit]
[virtual]
synchronizes the buffers with the associated character sequence
(virtual protected member function of std::basic_streambuf<CharT,Traits>) [edit]
Get area
[virtual]
obtains the number of characters available for input in the associated input sequence, if known
(virtual protected member function of std::basic_streambuf<CharT,Traits>) [edit]
[virtual]
reads characters from the associated input sequence to the get area
(virtual protected member function of std::basic_streambuf<CharT,Traits>) [edit]
[virtual]
reads characters from the associated input sequence to the get area and advances the next pointer
(virtual protected member function of std::basic_streambuf<CharT,Traits>) [edit]
[virtual]
reads multiple characters from the input sequence
(virtual protected member function of std::basic_streambuf<CharT,Traits>) [edit]
returns a pointer to the beginning, current character and the end of the get area
(protected member function) [edit]
advances the next pointer in the input sequence
(protected member function) [edit]
repositions the beginning, next, and end pointers of the input sequence
(protected member function) [edit]
Put area
[virtual]
writes multiple characters to the output sequence
(virtual protected member function of std::basic_streambuf<CharT,Traits>) [edit]
[virtual]
writes characters to the associated output sequence from the put area
(virtual protected member function of std::basic_streambuf<CharT,Traits>) [edit]
returns a pointer to the beginning, current character and the end of the put area
(protected member function) [edit]
advances the next pointer of the output sequence
(protected member function) [edit]
repositions the beginning, next, and end pointers of the output sequence
(protected member function) [edit]
Putback
[virtual]
puts a character back into the input sequence, possibly modifying the input sequence
(virtual protected member function of std::basic_streambuf<CharT,Traits>) [edit]