std::basic_stringbuf<CharT,Traits,Allocator>::seekpos
Von cppreference.com
< cpp | io | basic stringbuf
| protected: virtual pos_type seekpos( pos_type sp, |
||
Positioniert std::basic_streambuf::gptr und/oder std::basic_streambuf::pptr, wenn möglich, auf die von sp angegebene Position.
Führt effektiv seekoff(off_type(sp), std::ios_base::beg, which) aus.
Inhalt |
[bearbeiten] Parameter
| sp | - | Stream-Position, wie sie von seekoff() oder seekpos() erhalten wurde | ||||||
| which | - | legt fest, ob die Eingabesequenzen, die Ausgabesequenz oder beide betroffen sind. Es kann eine oder eine Kombination der folgenden Konstanten sein:
|
[bearbeiten] Rückgabewert
sp bei Erfolg oder pos_type(off_type(-1)) bei Fehler.
[bearbeiten] Hinweise
seekpos() wird von std::basic_streambuf::pubseekpos() aufgerufen, welche von den Ein-Argument-Versionen von std::basic_istream::seekg() und std::basic_ostream::seekp() aufgerufen wird.
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#include <sstream> #include <iostream> struct mybuf : std::stringbuf { mybuf(const std::string& str) : std::stringbuf(str) {} pos_type seekpos(pos_type sp, std::ios_base::openmode which) { std::cout << "Before seekpos(" << sp << "), size of the get area is " << egptr() - eback() << " with " << egptr() - gptr() << " read positions available.\n"; pos_type rc = std::stringbuf::seekpos(sp, which); std::cout << "seekpos() returns " << rc << ".\nAfter the call, " << "size of the get area is " << egptr() - eback() << " with " << egptr() - gptr() << " read positions available.\n"; return rc; } }; int main() { mybuf buf("12345"); std::iostream stream(&buf); stream.seekg(2); }
Ausgabe
Before seekpos(2), size of the get area is 5 with 5 read positions available. seekpos() returns 2. After the call, size of the get area is 5 with 3 read positions available.
[bearbeiten] 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 375 | C++98 | statische konstante Member von std::ios_base waren fälschlicherweise als Member von std::basic_ios angegeben |
korrigiert |
| LWG 564 | C++98 | war unklar, wie gptr und/oder pptr neu positioniert werden sollen |
sie werden von seekoff() neu positioniert |
[bearbeiten] Siehe auch
| ruft seekpos() auf (öffentliche Member-Funktion von std::basic_streambuf<CharT,Traits>) | |
| [virtuell] |
positioniert den nächsten Zeiger in der Eingabesequenz, Ausgabesequenz oder beidem neu, unter Verwendung relativer Adressierung (virtuelle geschützte Memberfunktion) |
| [virtuell] |
positioniert die Dateiposition neu, unter Verwendung absoluter Adressierung (virtual protected member function of std::basic_filebuf<CharT,Traits>) |
| [virtuell] |
positioniert den nächsten Zeiger in der Eingabesequenz, Ausgabesequenz oder beidem neu, unter Verwendung absoluter Adressierung (virtual protected member function of std::strstreambuf) |