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; const int 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 extraction std::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) | 


