operator>>(std::basic_istream)
定义于头文件 <istream> |
||
template< class CharT, class Traits > basic_istream<CharT, Traits>& |
(1) | |
(2) | ||
template< class CharT, class Traits> basic_istream<CharT, Traits>& |
(C++20 前) | |
template< class CharT, class Traits, std::size_t N > basic_istream<CharT, Traits>& |
(C++20 起) | |
template< class Istream, class T > Istream&& |
(3) | (C++11 起) |
ch
。如果无可用字符,则设置 failbit(此外还会设置 eofbit,这是 FormattedInputFunction 的要求)。s
指向。当满足以下任何条件时,提取停止:- 找到空白字符(由 ctype<CharT> facet 决定)。空白字符不被提取。
|
(C++20 前) |
|
(C++20 起) |
- 输入序列中发生文件结束(这也会设置 eofbit)。
Istream
是公开且明确地从 std::ios_base 派生的类类型时才参与重载决议。目录 |
[编辑] 注意
提取作为流最后一个字符的单个字符不会设置 eofbit
:这与其他格式化输入函数(例如使用 operator>> 提取最后一个整数)不同,但此行为与 std::scanf 使用 "%c" 格式说明符时的行为匹配。
[编辑] 参数
st | - | 用于提取数据的输入流 |
ch | - | 对字符的引用,用于存储提取的字符 |
s | - | 指向(C++20 前) 字符数组的指针,用于存储提取的字符 |
[编辑] 返回值
[编辑] 示例
#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'; }
输出
c = n cstr = greet f = 1.23
[编辑] 缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
缺陷报告 | 应用于 | 发布时的行为 | 正确的行为 |
---|---|---|---|
LWG 13 | C++98 | n 的定义提及了不存在的名称 eos | 替换为 CharT() |
LWG 68 | C++98 | 重载 (2) 的输出末尾未存储空字符 | 存储一个空字符 |
LWG 1203 | C++98 | 右值流的重载返回了基类的左值引用 | 返回右值引用 到派生类 |
LWG 2328 | C++98 | 右值流的重载要求另一个参数为左值 | 改为接受右值 |
LWG 2534 | C++98 | 右值流的重载未受约束 | 已受约束 |
[编辑] 参阅
提取格式化数据 (公有成员函数) |