std::basic_istream<CharT,Traits>::operator>>
来自cppreference.com
| |
(1) | |
| |
(2) | |
| |
(3) | |
| |
(4) | |
| |
(5) | (C++11 起) |
| |
(6) | (C++11 起) |
| |
(7) | |
| |
(8) | |
| |
(9) | |
| |
(10) | |
| |
(11) | |
| |
(12) | |
| |
(13) | |
| (14) | (C++23 起) | |
| |
(15) | |
| |
(16) | |
| |
(17) | |
| |
(18) | |
从输入流提取值。
1-11) 跳过潜在的前导空格并提取值。将提取到的值存储到给定的引用
value。 此函数表现为有格式输入函数 (FormattedInputFunction) 。构造并检查 sentry 对象(可能会跳过前导空格),通过调用 std::num_get::get() 提取值。
12) 跳过潜在的前导空格并提取
short 值。将提取到的值存储到给定的引用 value。 此函数表现为有格式输入函数 (FormattedInputFunction) 。构造并检查 sentry 对象(可能会跳过前导空格),通过调用 std::num_get::get() 提取
long 值 lval,然后:
- 如果
lval < std::numeric_limits<short>::min(),那么就会设置failbit并将std::numeric_limits<short>::min()存储到val。 - 否则,如果
std::numeric_limits<short>::max() < lval,那么就会设置failbit并将std::numeric_limits<short>::max()存储到val。 - 否则,将
static_cast<short>(lval)存储到val。
13) 跳过潜在的前导空格并提取
int 值。将提取到的值存储到给定的引用 value。 此函数表现为有格式输入函数 (FormattedInputFunction) 。构造并检查 sentry 对象(可能会跳过前导空格),通过调用 std::num_get::get() 提取
long 值 lval,然后:
- 如果
lval < std::numeric_limits<int>::min(),那么就会设置failbit并将std::numeric_limits<int>::min()存储到val。 - 否则,如果
std::numeric_limits<int>::max() < lval,那么就会设置failbit并将std::numeric_limits<int>::max()存储到val。 - 否则,将
static_cast<int>(lval)存储到val。
按以下方法确定标准浮点数类型
FP:
- 如果
/* 扩展浮点数类型 */的浮点数转换等级小于或等于float的对应等级,那么FP是float。 - 否则,如果
/* 扩展浮点数类型 */的浮点数转换等级小于或等于double的对应等级,那么FP是double。 - 否则,
FP是long double。
此函数表现为有格式输入函数 (FormattedInputFunction) 。构造并检查 sentry 对象(可能会跳过前导空格),通过调用 std::num_get::get() 提取
FP 值 fval,然后:
- 如果
fval < -std::numeric_limits</* 扩展浮点数类型 */>::max(),那么就会设置failbit并将-std::numeric_limits</* 扩展浮点数类型 */>::max()存储到val。 - 否则,如果
std::numeric_limits</* 扩展浮点数类型 */>::max() < fval,那么就会设置failbit并将std::numeric_limits</* 扩展浮点数类型 */>::max()存储到val。 - 否则,将
static_cast</* 扩展浮点数类型 */>(fval)存储到val。
15-17) 调用
func(*this),其中 func 是输入/输出操纵符。18) 表现为无格式输入函数 (UnformattedInputFunction) 。在构造并检查 sentry 对象后,从
*this 提取所有数据并将它存储到 sb。满足下列条件之一时停���提取:
- 输入序列上出现文件尾;
- 输出序列中插入失败(此时不会提取要被插入的字符);
- 出现异常(此时异常会被捕获,而且只有在未提取到任何字符并且
exceptions()中启用了failbit时才会重抛)。
sb 是空指针或未插入字符到 sb 中,那么就会调用 setstate(failbit)(启用时会抛出 std::ios_base::failure)。如果提取失败(比如当预期数字时输入了字母),那么写入零到 value 并设置 failbit。对于有符号整数,如果提取结果对于 value 过大或过小,那么(分别)写入 std::numeric_limits<T>::max() 或 std::numeric_limits<T>::min() 并设置 failbit 标志。对于无符号整数,如果提取结果对于 value 过大或过小,那么写入 std::numeric_limits<T>::max() 并设置 failbit 标志。
参数
| value | - | 到要存储提取值到的整数或浮点数的引用 |
| func | - | 指向输入/输出操纵符函数的指针 |
| sb | - | 指向要写入全部数据到的流缓冲的指针 |
返回值
1-16,18)
*this17)
func(*this)注解
对于重载 (14),当扩展浮点数类型的浮点数转换等级与任何标准浮点数类型的等级都不相同时,转换过程中的双重舍入会导致不精确结果。在需要最大精确性的场合可以使用 std::from_chars()。
示例
运行此代码
#include <iomanip>
#include <iostream>
#include <sstream>
int main()
{
std::string input = "41 3.14 false hello world";
std::istringstream stream(input);
int n;
double f;
bool b;
stream >> n >> f >> std::boolalpha >> b;
std::cout << "n = " << n << '\n'
<< "f = " << f << '\n'
<< "b = " << std::boolalpha << b << '\n';
// 用 streambuf 重载提取剩余内容
stream >> std::cout.rdbuf();
std::cout << '\n';
}
输出:
n = 41
f = 3.14
b = false
hello world
缺陷报告
下列更改行为的缺陷报告追溯地应用于以前出版的 C++ 标准。
| 缺陷报告 | 应用于 | 出版时的行为 | 正确行为 |
|---|---|---|---|
| LWG 64 | C++98 | 不明确重载 (18) 是否只能重抛因调用setstate(failbit) 而抛出的 ios_base::failure
|
可以重抛所有异常 |
| LWG 118 | C++98 | 重载 (12,13) 通过 num_get::get 代理提取操作, 但它没有为 short 以及 int 重载
|
输入 short 或int 时会提取 long
|
| LWG 413 | C++98 | 重载 (18) 只会重抛在从 sb 提取字符时抛出的异常,但是字符是从 *this 提取的
|
将 sb 改成 *this
|
| LWG 567 | C++98 | 重载 (18) 因 LWG 问题 60 的解决方案而表现为 有格式输入函数 (FormattedInputFunction) |
表现为 无格式输入函数 (UnformattedInputFunction) |
| LWG 661 | C++98 | 重载 (12,13) 由于 LWG 问题 118 的解决 方案不会将提取到的数字存储到 value
|
在未发生上溢的情况下会存储 |
| LWG 696 | C++98 | 提取失败时不会更改 value
|
设为零或最大/最小值 |
参阅
| 提取字符和字符数组 (函数模板) | |
| 执行字符串的流输入与输出 (函数模板) | |
| 执行 bitset 的流输入和输出 (函数) | |
| 复数的序列化和反序列化 (函数模板) | |
(C++11) |
执行伪随机数引擎的流输入和输出 (函数模板) |
(C++11) |
执行伪随机数分布的流输入和输出 (函数模板) |
| 按区块提取字符 (公开成员函数) | |
| 提取已经可用的字符区块 (公开成员函数) | |
| 提取字符 (公开成员函数) | |
| 持续提取字符,直到找到给定字符 (公开成员函数) | |
(C++17) |
转换字符序列到整数或浮点数 (函数) |