std::strstreambuf::seekpos
| protected: virtual pos_type seekpos( pos_type sp, |
(veraltet in C++98) (entfernt in C++26) |
|
Positioniert std::basic_streambuf::gptr und/oder std::basic_streambuf::pptr, falls möglich, an die von sp angegebene Position.
Wenn std::ios_base::in in which gesetzt ist, wird versucht, gptr() (den nächsten Zeiger im Lese-Bereich) neu zu positionieren. Wenn std::ios_base::out in which gesetzt ist, wird versucht, pptr() (den nächsten Zeiger im Schreib-Bereich) neu zu positionieren. Wenn keiner der Bits in which gesetzt ist, schlägt die Operation fehl.
Jeder nächste Zeiger wird wie folgt neu positioniert:
- Wenn der nächste Zeiger null ist, schlägt die Operation fehl.
- Andernfalls wird der neue Offset newoff (vom Typ
off_type) durch Aufruf von sp.offset() bestimmt. Wenn newoff negativ ist, außerhalb des Puffers liegt oder ungültig ist, schlägt die Operation fehl. - Andernfalls wird der nächste Zeiger zugewiesen, als ob durch gptr() = eback() + newoff oder pptr() = pbase() + newoff.
Inhalt |
[edit] Parameter
| sp | - | Stream-Position, wie z. B. eine, die 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:
|
[edit] Rückgabewert
Der resultierende Offset, konvertiert zu pos_type bei Erfolg oder pos_type(off_type(-1)) bei Fehler.
[edit] 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.
[edit] Beispiel
#include <cstring> #include <iostream> #include <strstream> struct mybuf : std::strstreambuf { mybuf(const char* str) : std::strstreambuf(str, std::strlen(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::strstreambuf::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.
[edit] 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 55 | C++98 | seekpos gab einen undefiniertenungültige Stream-Position bei Fehler |
pos_type(off_type(-1)) wird bei Fehler zurückgegeben. |
[edit] Siehe auch
| [virtuell] |
positioniert den nächsten Zeiger in der Eingabesequenz, Ausgabesequenz oder beidem neu, unter Verwendung relativer Adressierung (virtuelle geschützte Memberfunktion) |
| [virtuell] |
positioniert den nächsten Zeiger in der Eingabesequenz, Ausgabesequenz oder beidem neu, unter Verwendung absoluter Adressierung (virtuelle geschützte Member-Funktion von std::basic_streambuf<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::basic_stringbuf<CharT,Traits,Allocator>) |
| [virtuell] |
positioniert die Dateiposition neu, unter Verwendung absoluter Adressierung (virtual protected member function of std::basic_filebuf<CharT,Traits>) |