std::basic_streambuf<CharT,Traits>::setp
Von cppreference.com
< cpp | io | basic streambuf
| protected: void setp( char_type* pbeg, char_type* pend ); |
||
Setzt die Werte der Zeiger, die den Put-Bereich definieren.
Nach dem Aufruf sind pbase() == pbeg, pptr() == pbeg und epptr() == pend alle true.
Wenn irgendeiner der Werte in [pbeg, pend) kein gültiger Bereich ist, ist das Verhalten undefiniert.
Inhalt |
[bearbeiten] Parameter
| pbeg | - | Zeiger auf den neuen Anfang des Put-Bereichs |
| pend | - | Zeiger auf das neue Ende des Put-Bereichs |
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#include <array> #include <cstddef> #include <iostream> // Buffer for std::ostream implemented by std::array template<std::size_t size, class CharT = char> struct ArrayedStreamBuffer : std::basic_streambuf<CharT> { using Base = std::basic_streambuf<CharT>; using char_type = typename Base::char_type; ArrayedStreamBuffer() { // put area pointers to work with “buffer” Base::setp(buffer.data(), buffer.data() + size); } void print_buffer() { for (char_type i : buffer) { if (i == 0) std::cout << "\\0"; else std::cout << i; std::cout << ' '; } std::cout << '\n'; } private: std::array<char_type, size> buffer{}; // value-initialize “buffer” }; int main() { ArrayedStreamBuffer<10> streambuf; std::ostream stream(&streambuf); stream << "hello"; stream << ","; streambuf.print_buffer(); }
Ausgabe
h e l l o , \0 \0 \0 \0
[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 4023 | C++98 | setp erforderte nicht, dass die Ausgabesequenz ein gültiger Bereich ist |
requires |
[bearbeiten] Siehe auch
| positioniert die Zeiger für Anfang, nächsten und Ende der Eingabesequenz neu (geschützte Member-Funktion) |