Namensräume
Varianten
Aktionen

std::basic_stringbuf<CharT,Traits,Allocator>::seekpos

Von cppreference.com
< cpp‎ | io‎ | basic stringbuf
 
 
 
 
protected:

virtual pos_type seekpos( pos_type sp,

                          std::ios_base::openmode which = std::ios_base::in | std::ios_base::out );

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:
Konstante Erklärung
in beeinflusst die Eingabesequenz
out beeinflusst die Ausgabesequenz

[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

#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>) [bearbeiten]
[virtuell]
positioniert den nächsten Zeiger in der Eingabesequenz, Ausgabesequenz oder beidem neu, unter Verwendung relativer Adressierung
(virtuelle geschützte Memberfunktion) [bearbeiten]
[virtuell]
positioniert die Dateiposition neu, unter Verwendung absoluter Adressierung
(virtual protected member function of std::basic_filebuf<CharT,Traits>) [edit]
[virtuell]
positioniert den nächsten Zeiger in der Eingabesequenz, Ausgabesequenz oder beidem neu, unter Verwendung absoluter Adressierung
(virtual protected member function of std::strstreambuf) [edit]