I/O manipulators | ||||
Print functions(C++23) | ||||
C-style I/O | ||||
Buffers | ||||
(C++23) | ||||
(C++98/26*) | ||||
(C++20) | ||||
Streams | ||||
Abstractions | ||||
File I/O | ||||
String I/O | ||||
Array I/O | ||||
(C++23) | ||||
(C++23) | ||||
(C++23) | ||||
(C++98/26*) | ||||
(C++98/26*) | ||||
(C++98/26*) | ||||
Synchronized Output | ||||
(C++20) | ||||
Types | ||||
Error category interface | ||||
(C++11) | ||||
(C++11) |
|
|
int_type sungetc(); | ||
If a putback position is available in the get area (gptr()> eback()), then decrements the next pointer (gptr()) and returns the character it now points to.
If a putback position is not available, then callspbackfail() to back up the input sequence if possible.
The I/O stream functionbasic_istream::unget is implemented in terms of this function.
Contents |
(none)
If putback position was available, returns the character that the next pointer is now pointing at, converted toint_type
withTraits::to_int_type(*gptr()). The next single-character input from this streambuf will return this character.
If putback position was not available, returns whatpbackfail() returns, which isTraits::eof() on failure.
#include <iostream>#include <sstream> int main(){std::stringstream s("abcdef");// gptr() points to 'a'char c1= s.get();// c = 'a', gptr() now points to 'b'char c2= s.rdbuf()->sungetc();// same as s.unget(): gptr() points to 'a' againchar c3= s.get();// c3 = 'a', gptr() now points to 'b'char c4= s.get();// c4 = 'b', gptr() now points to 'c'std::cout<< c1<< c2<< c3<< c4<<'\n'; s.rdbuf()->sungetc();// back to 'b' s.rdbuf()->sungetc();// back to 'a'int eof= s.rdbuf()->sungetc();// nothing to unget: pbackfail() failsif(eof==EOF)std::cout<<"Nothing to unget after 'a'\n";}
Output:
aaabNothing to unget after 'a'
puts one character back in the input sequence (public member function)[edit] | |
unextracts a character (public member function of std::basic_istream<CharT,Traits> )[edit] |