Namespaces
Variants

std:: ostreambuf_iterator

From cppreference.net
Iterator library
Iterator concepts
Iterator primitives
Algorithm concepts and utilities
Indirect callable concepts
Common algorithm requirements
(C++20)
(C++20)
(C++20)
Utilities
(C++20)
Iterator adaptors
Range access
(C++11) (C++14)
(C++14) (C++14)
(C++11) (C++14)
(C++14) (C++14)
(C++17) (C++20)
(C++17)
(C++17)
Definiert im Header <iterator>
template < class CharT, class Traits = std:: char_traits < CharT > >

class ostreambuf_iterator

: public std:: iterator < std:: output_iterator_tag , void , void , void , void >
(bis C++17)
template < class CharT, class Traits = std:: char_traits < CharT > >
class ostreambuf_iterator ;
(seit C++17)

std::ostreambuf_iterator ist ein Single-Pass- LegacyOutputIterator , der aufeinanderfolgende Zeichen in das std::basic_streambuf -Objekt schreibt, für das es konstruiert wurde. Der tatsächliche Schreibvorgang wird ausgeführt, wenn der Iterator (ob dereferenziert oder nicht) zugewiesen wird. Das Inkrementieren des std::ostreambuf_iterator ist eine No-Op-Operation.

In einer typischen Implementierung sind die einzigen Datenmitglieder von std::ostreambuf_iterator ein Zeiger auf den assoziierten std::basic_streambuf und ein boolesches Flag, das anzeigt, ob das Dateiende erreicht wurde.

Inhaltsverzeichnis

Mitgliedertypen

Mitgliedertyp Definition
iterator_category std:: output_iterator_tag
value_type void
difference_type

void

(bis C++20)

std::ptrdiff_t

(seit C++20)
pointer void
reference void
char_type CharT
traits_type Traits
streambuf_type std:: basic_streambuf < CharT, Traits >
ostream_type std:: basic_ostream < CharT, Traits >

Die Member-Typen iterator_category , value_type , difference_type , pointer und reference müssen durch Vererbung von std:: iterator < std:: output_iterator_tag , void , void , void , void > erhalten werden.

(bis C++17)

Memberfunktionen

konstruiert einen neuen ostreambuf_iterator
(öffentliche Elementfunktion)
(Destruktor)
(implizit deklariert)
zerstört einen ostreambuf_iterator
(öffentliche Elementfunktion)
schreibt ein Zeichen in die assoziierte Ausgabesequenz
(öffentliche Elementfunktion)
No-Op
(öffentliche Elementfunktion)
No-Op
(öffentliche Elementfunktion)
prüft, ob die Ausgabe fehlgeschlagen ist
(öffentliche Elementfunktion)

Beispiel

#include <algorithm>
#include <iostream>
#include <iterator>
#include <string>
int main()
{
    std::string s = "This is an example\n";
    std::copy(s.begin(), s.end(), std::ostreambuf_iterator<char>(std::cout));
}

Ausgabe:

This is an example

Siehe auch

Eingabe-Iterator, der von std::basic_streambuf liest
(Klassentemplate)
Ausgabe-Iterator, der in std::basic_ostream schreibt
(Klassentemplate)