Namespaces
Variants

std:: istream_iterator

From cppreference.net
Iterator library
Iterator concepts
Iterator primitives
Algorithm concepts and utilities
Indirect callable concepts
Common algorithm requirements
(C++20)
(C++20)
(C++20)
Utilities
(C++20)
Iterator adaptors
Range access
(C++11) (C++14)
(C++14) (C++14)
(C++11) (C++14)
(C++14) (C++14)
(C++17) (C++20)
(C++17)
(C++17)
定义于头文件 <iterator>
template < class T,

class CharT = char ,
class Traits = std:: char_traits < CharT > ,
class Distance = std:: ptrdiff_t >
class istream_iterator

: public std:: iterator < std:: input_iterator_tag , T, Distance, const T * , const T & >
(C++17 前)
template < class T,

class CharT = char ,
class Traits = std:: char_traits < CharT > ,
class Distance = std:: ptrdiff_t >

class istream_iterator ;
(C++17 起)

std::istream_iterator 是一种单次遍历输入迭代器,通过调用相应的 operator >> ,从构造时指定的 std::basic_istream 对象中连续读取类型为 T 的对象。实际读取操作在迭代器递增时执行,而非解引用时。首个对象在迭代器构造时即被读取。解引用操作仅返回最近读取对象的副本。

默认构造的 std::istream_iterator 被称为 流结束 迭代器。当有效的 std::istream_iterator 到达底层流的末尾时,它会变得与流结束迭代器相等。此时再对其进行解引用或递增操作将引发未定义行为。即使底层流的状态发生变化,流结束迭代器也会始终保持流结束状态。除非重新赋值,否则它无法再变为非流结束迭代器。

std::istream_iterator 的典型实现包含两个数据成员:一个指向关联 std::basic_istream 对象的指针,以及最近读取的类型为 T 的值。

T 必须满足 DefaultConstructible CopyConstructible CopyAssignable 要求。

目录

成员类型

成员类型 定义
iterator_category std:: input_iterator_tag
value_type T
difference_type Distance
pointer const T *
reference const T &
char_type CharT
traits_type Traits
istream_type std:: basic_istream < CharT, Traits >

成员类型 iterator_category value_type difference_type pointer reference 需要通过继承自 std:: iterator < std:: input_iterator_tag , T, Distance, const T * , const T & > 来获得。

(C++17 前)

成员函数

构造新的 istream_iterator
(公开成员函数)
销毁 istream_iterator (包含缓存值)
(公开成员函数)
返回当前元素
(公开成员函数)
推进迭代器
(公开成员函数)

非成员函数

(C++20 中移除)
比较两个 istream_iterator
(函数模板)

注释

在读取字符时, std::istream_iterator 默认跳过空白字符(除非使用 std::noskipws 或等效方法禁用),而 std::istreambuf_iterator 则不会跳过。此外, std::istreambuf_iterator 效率更高,因为它避免了为每个字符构造和析构哨兵对象的开销。

示例

#include <algorithm>
#include <iostream>
#include <iterator>
#include <numeric>
#include <sstream>
int main()
{
    std::istringstream str("0.1 0.2 0.3 0.4");
    std::partial_sum(std::istream_iterator<double>(str),
                     std::istream_iterator<double>(),
                     std::ostream_iterator<double>(std::cout, " "));
    std::istringstream str2("1 3 5 7 8 9 10");
    auto it = std::find_if(std::istream_iterator<int>(str2),
                           std::istream_iterator<int>(),
                           [](int i){ return i % 2 == 0; });
    if (it != std::istream_iterator<int>())
        std::cout << "\nThe first even number is " << *it << ".\n";
    //流中剩余" 9 10"
}

输出:

0.1 0.3 0.6 1 
第一个偶数是8。

缺陷报告

以下行为变更缺陷报告被追溯应用于先前发布的C++标准。

缺陷报告 适用范围 发布时的行为 正确行为
P0738R2 C++98 首次读取操作可能延迟到首次解引用时执行 始终在构造函数中执行

参见

写入到 std::basic_ostream 的输出迭代器
(类模板)
std::basic_streambuf 读取的输入迭代器
(类模板)