Poznámka:
Přístup k této stránce vyžaduje autorizaci. Můžete se zkusit přihlásit nebo změnit adresáře.
Přístup k této stránce vyžaduje autorizaci. Můžete zkusit změnit adresáře.
Šablona třídy ostreambuf_iterator popisuje výstupní objekt iterátoru, který zapisuje následné prvky znaků do výstupního datového proudu pomocí operátoru>> extrakce. Liší ostreambuf_iteratorse od těch, které ostream_iterator Třída mají znaky místo obecného typu v typu objektu, který se vkládá do výstupního datového proudu.
Syntaxe
template <class CharType = char, class Traits = char_traits <CharType>>
Parametry
CharType
Typ, který představuje typ znaku pro ostreambuf_iterator. Tento argument je nepovinný a výchozí hodnota je char.
Rysy
Typ, který představuje typ znaku pro ostreambuf_iterator. Tento argument je nepovinný a výchozí hodnota je char_traits<CharType.>
Poznámky
Třída ostreambuf_iterator musí splňovat požadavky na výstupní iterátor. Algoritmy lze zapisovat přímo do výstupních datových proudů pomocí .ostreambuf_iterator Třída poskytuje iterátor datového proudu na nízké úrovni, který umožňuje přístup k nezpracovanému (neformátovanému) proudu dat ve formě znaků a schopnost obejít ukládání do vyrovnávací paměti a překlady znaků spojené s iterátory datového proudu vysoké úrovně.
Konstruktory
| Konstruktor | Popis |
|---|---|
| ostreambuf_iterator | ostreambuf_iterator Vytvoří inicializovaný objekt pro zápis znaků do výstupního datového proudu. |
Typedefs
| Název typu | Popis |
|---|---|
| char_type | Typ, který poskytuje typ znaku ostreambuf_iterator. |
| ostream_type | Typ, který poskytuje typ datového ostream_iteratorproudu . |
| streambuf_type | Typ, který poskytuje typ datového ostreambuf_iteratorproudu . |
| traits_type | Typ, který poskytuje typ znakových ostream_iteratorvlastností . |
Členské funkce
| Členová funkce | Popis |
|---|---|
| neúspěšný | Ověřuje selhání vložení do vyrovnávací paměti výstupního datového proudu. |
Operátory
| Operátor | Popis |
|---|---|
| operátor* | Operátor dereferencing použitý k implementaci výstupního výrazu iterátoru * i = x. |
| operator++ | Nefunkční inkrementační operátor, který vrací stejný ostreambuf_iterator objekt, který byl vyřešen před zavolání operace. |
| operator= | Operátor vloží znak do přidružené vyrovnávací paměti datového proudu. |
Požadavky
Header:<iterator>
Obor názvů: std
ostreambuf_iterator::char_type
Typ, který poskytuje typ znaku ostreambuf_iterator.
typedef CharType char_type;
Poznámky
Typ je synonymem pro parametr CharTypešablony .
Příklad
// ostreambuf_iterator_char_type.cpp
// compile with: /EHsc
#include <iterator>
#include <vector>
#include <iostream>
int main( )
{
using namespace std;
typedef ostreambuf_iterator<char>::char_type CHT1;
typedef ostreambuf_iterator<char>::traits_type CHTR1;
// ostreambuf_iterator for stream cout
// with new line delimiter:
ostreambuf_iterator< CHT1, CHTR1> charOutBuf ( cout );
// Standard iterator interface for writing
// elements to the output streambuf:
cout << "The characters written to the output stream\n"
<< " by charOutBuf are: ";
*charOutBuf = 'O';
charOutBuf++;
*charOutBuf = 'U';
charOutBuf++;
*charOutBuf = 'T';
charOutBuf++;
cout << "." << endl;
}
/* Output:
The characters written to the output stream
by charOutBuf are: OUT.
*/
ostreambuf_iterator::failed
Ověřuje selhání vložení do vyrovnávací paměti výstupního datového proudu.
bool failed() const throw();
Návratová hodnota
true pokud do vyrovnávací paměti výstupního datového proudu nedošlo dříve k chybě vložení; jinak false.
Poznámky
Členová funkce vrátí true , pokud v jakémkoli předchozím použití členu operator=volání subf_->sputc vrácen eof.
Příklad
// ostreambuf_iterator_failed.cpp
// compile with: /EHsc
#include <iterator>
#include <vector>
#include <iostream>
int main( )
{
using namespace std;
// ostreambuf_iterator for stream cout
ostreambuf_iterator<char> charOut ( cout );
*charOut = 'a';
charOut ++;
*charOut = 'b';
charOut ++;
*charOut = 'c';
cout << " are characters output individually." << endl;
bool b1 = charOut.failed ( );
if (b1)
cout << "At least one insertion failed." << endl;
else
cout << "No insertions failed." << endl;
}
/* Output:
abc are characters output individually.
No insertions failed.
*/
ostreambuf_iterator::operator*
Nonfunctional dereferencing operator used to implement the output iterator expression * i = x.
ostreambuf_iterator<CharType, Traits>& operator*();
Návratová hodnota
Objekt iterátoru ostreambuf.
Poznámky
Tento operátor funguje pouze ve výstupním výrazu iterátoru * i = x pro výstupní znaky pro vyrovnávací paměť datového proudu. Použije se na iterátor ostreambuf, vrátí iterátor; *iter vrátí iter,
Příklad
// ostreambuf_iterator_op_deref.cpp
// compile with: /EHsc
#include <iterator>
#include <vector>
#include <iostream>
int main( )
{
using namespace std;
// ostreambuf_iterator for stream cout
// with new line delimiter
ostreambuf_iterator<char> charOutBuf ( cout );
// Standard iterator interface for writing
// elements to the output stream
cout << "Elements written to output stream:" << endl;
*charOutBuf = 'O';
charOutBuf++; // no effect on iterator position
*charOutBuf = 'U';
*charOutBuf = 'T';
}
/* Output:
Elements written to output stream:
OUT
*/
ostreambuf_iterator::operator++
Nefunkční operátor přírůstku, který vrátí ostreamový iterátor na stejný znak, který byl vyřešen před zavolání operace.
ostreambuf_iterator<CharType, Traits>& operator++();
ostreambuf_iterator<CharType, Traits>& operator++(int);
Návratová hodnota
Odkaz na znak původně adresovaný nebo na objekt definovaný implementací, který je konvertibilní na ostreambuf_iterator<CharType, Traits.>
Poznámky
Operátor se používá k implementaci výstupního výrazu iterátoru * i = x.
Příklad
// ostreambuf_iterator_op_incr.cpp
// compile with: /EHsc
#include <iterator>
#include <vector>
#include <iostream>
int main( )
{
using namespace std;
// ostreambuf_iterator for stream cout
// with new line delimiter
ostreambuf_iterator<char> charOutBuf ( cout );
// Standard iterator interface for writing
// elements to the output stream
cout << "Elements written to output stream:" << endl;
*charOutBuf = 'O';
charOutBuf++; // No effect on iterator position
*charOutBuf = 'U';
*charOutBuf = 'T';
}
/* Output:
Elements written to output stream:
OUT
*/
ostreambuf_iterator::operator=
Operátor vloží znak do přidružené vyrovnávací paměti datového proudu.
ostreambuf_iterator<CharType, Traits>& operator=(CharType _Char);
Parametry
_Uklízečka
Znak, který se má vložit do vyrovnávací paměti datového proudu.
Návratová hodnota
Odkaz na znak vložený do vyrovnávací paměti datového proudu.
Poznámky
Operátor přiřazení použitý k implementaci výstupního výrazu iterátoru * i = x pro zápis do výstupního datového proudu.
Příklad
// ostreambuf_iterator_op_assign.cpp
// compile with: /EHsc
#include <iterator>
#include <vector>
#include <iostream>
int main( )
{
using namespace std;
// ostreambuf_iterator for stream cout
// with new line delimiter
ostreambuf_iterator<char> charOutBuf ( cout );
// Standard iterator interface for writing
// elements to the output stream
cout << "Elements written to output stream:" << endl;
*charOutBuf = 'O';
charOutBuf++; // No effect on iterator position
*charOutBuf = 'U';
*charOutBuf = 'T';
}
/* Output:
Elements written to output stream:
OUT
*/
ostreambuf_iterator::ostreambuf_iterator
ostreambuf_iterator Vytvoří inicializovaný objekt pro zápis znaků do výstupního datového proudu.
ostreambuf_iterator(streambuf_type* strbuf) throw();
ostreambuf_iterator(ostream_type& Ostr) throw();
Parametry
strbuf
Výstupní objekt streambuf použitý k inicializaci výstupního ukazatele vyrovnávací paměti datového proudu.
Ostr
Výstupní objekt streamu použitý k inicializaci výstupního ukazatele vyrovnávací paměti datového proudu.
Poznámky
První konstruktor inicializuje výstupní ukazatel vyrovnávací paměti datového proudu pomocí strbuf.
Druhý konstruktor inicializuje výstupní stream-buffer ukazatel s Ostr. rdbuf. Uložený ukazatel nesmí být nulovým ukazatelem.
Příklad
// ostreambuf_iteratorOstreambuf_iterator.cpp
// compile with: /EHsc
#include <iterator>
#include <vector>
#include <iostream>
int main( )
{
using namespace std;
// ostreambuf_iterator for stream cout
ostreambuf_iterator<char> charOut ( cout );
*charOut = 'O';
charOut ++;
*charOut = 'U';
charOut ++;
*charOut = 'T';
cout << " are characters output individually." << endl;
ostreambuf_iterator<char> strOut ( cout );
string str = "These characters are being written to the output stream.\n ";
copy ( str.begin ( ), str. end ( ), strOut );
}
/* Output:
OUT are characters output individually.
These characters are being written to the output stream.
*/
ostreambuf_iterator::ostream_type
Typ, který poskytuje typ datového ostream_iteratorproudu .
typedef basicOstream<CharType, Traits> ostream_type;
Poznámky
Typ je synonymem pro basicOstream<CharType, Traits. >
Příklad
Příklad deklarace a použití ostream_typenajdete v ostreambuf_iterator .
ostreambuf_iterator::streambuf_type
Typ, který poskytuje typ datového ostreambuf_iteratorproudu .
typedef basic_streambuf<CharType, Traits> streambuf_type;
Poznámky
Typ je synonymem pro basic_streambuf<CharType, Traits>, třídu streamu pro vstupně-výstupní vyrovnávací paměti, která se stane, když se streambuf specializují na typ charznaku .
Příklad
Příklad deklarace a použití streambuf_typenajdete v ostreambuf_iterator .
ostreambuf_iterator::traits_type
Typ, který poskytuje typ znakových ostream_iteratorvlastností .
typedef Traits traits_type;
Poznámky
Typ je synonymem pro parametr Traitsšablony .
Příklad
// ostreambuf_iterator_traits_type.cpp
// compile with: /EHsc
#include <iterator>
#include <vector>
#include <iostream>
int main( )
{
using namespace std;
typedef ostreambuf_iterator<char>::char_type CHT1;
typedef ostreambuf_iterator<char>::traits_type CHTR1;
// ostreambuf_iterator for stream cout
// with new line delimiter:
ostreambuf_iterator< CHT1, CHTR1> charOutBuf ( cout );
// Standard iterator interface for writing
// elements to the output streambuf:
cout << "The characters written to the output stream\n"
<< " by charOutBuf are: ";
*charOutBuf = 'O';
charOutBuf++;
*charOutBuf = 'U';
charOutBuf++;
*charOutBuf = 'T';
charOutBuf++;
cout << "." << endl;
}
/* Output:
The characters written to the output stream
by charOutBuf are: OUT.
*/
Viz také
<iterátor>
Bezpečný přístup z více vláken ve standardní knihovně C++
Standardní knihovna C++ – referenční dokumentace