operator>>(std::basic_istream)
Defined in header <istream> | ||
template<class CharT, class Traits > basic_istream<CharT, Traits>& | (1) | |
(2) | ||
template<class CharT, class Traits> basic_istream<CharT, Traits>& | (until C++20) | |
template<class CharT, class Traits, std::size_t N > basic_istream<CharT, Traits>& | (since C++20) | |
template<class Istream, class T > Istream&& | (3) | (since C++11) |
ch
. If no character is available, sets failbit (in addition to eofbit that is set as required of a FormattedInputFunction).s
. The extraction stops if any of the following conditions is met: - A whitespace character (as determined by the ctype<CharT> facet) is found. The whitespace character is not extracted.
| (until C++20) |
| (since C++20) |
- End of file occurs in the input sequence (this also sets eofbit).
Istream
is a class type publicly and unambiguously derived from std::ios_base.Contents |
[edit]Notes
Extracting a single character that is the last character of the stream does not set eofbit
: this is different from other formatted input functions, such as extracting the last integer with operator>>, but this behavior matches the behavior of std::scanf with "%c" format specifier.
[edit]Parameters
st | - | input stream to extract the data from |
ch | - | reference to a character to store the extracted character to |
s | - | pointer to(until C++20) a character array to store the extracted characters to |
[edit]Return value
[edit]Example
#include <iomanip>#include <iostream>#include <sstream> int main(){std::string input ="n greetings";std::istringstream stream(input); char c;constint MAX =6;char cstr[MAX]; stream >> c >>std::setw(MAX)>> cstr;std::cout<<"c = "<< c <<'\n'<<"cstr = "<< cstr <<'\n'; double f;std::istringstream("1.23")>> f;// rvalue stream extractionstd::cout<<"f = "<< f <<'\n';}
Output:
c = n cstr = greet f = 1.23
[edit]Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
DR | Applied to | Behavior as published | Correct behavior |
---|---|---|---|
LWG 13 | C++98 | the definition of n mentioned a non-existing name eos | replaced with CharT() |
LWG 68 | C++98 | no null characters were stored at the end of the output for overload (2) | stores a null character |
LWG 1203 | C++98 | overload for rvalue stream returned lvalue reference to the base class | returns rvalue reference to the derived class |
LWG 2328 | C++98 | overload for rvalue stream required another argument to be lvalue | made to accept rvalue |
LWG 2534 | C++98 | overload for rvalue stream was not constrained | constrained |
[edit]See also
extracts formatted data (public member function) |