std::basic_streambuf<CharT,Traits>:: setg
|
protected
:
void setg ( char_type * gbeg, char_type * gcurr, char_type * gend ) ; |
||
Legt die Werte der Zeiger fest, die den Lesebereich definieren.
Nach dem Aufruf sind eback ( ) == gbeg , gptr ( ) == gcurr und egptr ( ) == gend alle true .
Falls einer der Bereiche
[
gbeg
,
gend
)
,
[
gbeg
,
gcurr
)
oder
[
gcurr
,
gend
)
kein
gültiger Bereich
ist, ist das Verhalten undefiniert.
Inhaltsverzeichnis |
Parameter
| gbeg | - | Zeiger auf den neuen Anfang des Lesebereichs |
| gcurr | - | Zeiger auf das neue aktuelle Zeichen ( get pointer ) im Lesebereich |
| gend | - | Zeiger auf das neue Ende des Lesebereichs |
Beispiel
#include <iostream> #include <sstream> class null_filter_buf : public std::streambuf { std::streambuf* src; char ch; // single-byte buffer protected: int underflow() { traits_type::int_type i; while ((i = src->sbumpc()) == '\0') ; // skip zeroes if (!traits_type::eq_int_type(i, traits_type::eof())) { ch = traits_type::to_char_type(i); setg(&ch, &ch, &ch+1); // make one read position available } return i; } public: null_filter_buf(std::streambuf* buf) : src(buf) { setg(&ch, &ch + 1, &ch + 1); // buffer is initially full } }; void filtered_read(std::istream& in) { std::streambuf* orig = in.rdbuf(); null_filter_buf buf(orig); in.rdbuf(&buf); for (char c; in.get(c);) std::cout << c; in.rdbuf(orig); } int main() { char a[] = "This i\0s \0an e\0\0\0xample"; std::istringstream in(std::string(std::begin(a), std::end(a))); filtered_read(in); }
Ausgabe:
This is an example
Fehlerberichte
Die folgenden verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.
| DR | Angewendet auf | Verhalten wie veröffentlicht | Korrigiertes Verhalten |
|---|---|---|---|
| LWG 4023 | C++98 |
setg
forderte nicht, dass die Eingabesequenz ein gültiger Bereich sein muss
|
erfordert |
Siehe auch
|
positioniert die Anfangs-, Nächste- und End-Zeiger der Ausgabesequenz neu
(geschützte Elementfunktion) |