命名空间
变体
操作

std::experimental::ranges::for_each

来自 cppreference.cn
< cpp‎ | experimental‎ | ranges
 
 
实验性
技术规范
文件系统库 (filesystem TS)
库基础 (library fundamentals TS)
库基础 2 (library fundamentals TS v2)
库基础 3 (library fundamentals TS v3)
并行扩展 (parallelism TS)
并行扩展 2 (parallelism TS v2)
并发扩展 (concurrency TS)
并发扩展 2 (concurrency TS v2)
概念 (concepts TS)
范围 (ranges TS)
反射 (reflection TS)
数学特殊函数 (special functions TR)
实验性非 TS
模式匹配
线性代数
std::execution
契约
2D 图形
 
 
 
定义于头文件 <experimental/ranges/algorithm>
template< InputIterator I, Sentinel<I> S, class Proj = ranges::identity,

          IndirectUnaryInvocable<projected<I, Proj>> Fun >
ranges::tagged_pair<tag::in(I), tag::fun(Fun)>

    for_each( I first, S last, Fun f, Proj proj = Proj{} );
(1) (ranges TS)
template< InputRange R, class Proj = ranges::identity,

          IndirectUnaryInvocable<projected<ranges::iterator_t<R>, Proj>> Fun >
ranges::tagged_pair<tag::in(ranges::safe_iterator_t<R>), tag::fun(Fun)>

    for_each( R&& r, Fun f, Proj proj = Proj{} );
(2) (ranges TS)
1) 对范围 [firstlast) 中每个迭代器解引用的结果应用投影 proj,然后对投影结果调用给定的函数对象 f(即 ranges::invoke(f, ranges::invoke(proj, *i))),按顺序进行调用。
2)(1) 相同,但使用 r 作为源范围,如同使用 ranges::begin(r) 作为 firstranges::end(r) 作为 last

对于两个重载版本,如果迭代器类型是可变的,f 可以通过解引用的迭代器修改范围内的元素。如果 f 返回结果,结果将被忽略。

与其他算法不同,即使序列中的元素是可平凡复制的,for_each 也不允许复制它们。

std::for_each(仅要求 MoveConstructible)不同,这些函数要求 Fun 建模 CopyConstructible

尽管上面描述了声明,但算法声明的模板参数的实际数量和顺序是未指定的。因此,如果在调用算法时使用了显式模板参数,则该程序可能不具有可移植性。

目录

[编辑] 参数

first, last - 应用函数的范围
r - 应用函数的范围
f - 要应用于范围内每个投影元素的可调用对象
proj - 应用于元素的投影

[编辑] 返回值

一个 tagged_pair 对象,包含以下两个成员

  • 第一个成员,带有标签 tag::in,是源范围的过尾迭代器(即,类型为 I 且与哨兵 last 相等的迭代器)。
  • 第二个成员,带有标签 tag::fun,从 std::move(f) 初始化(在函数对象的所有应用之后)。

[编辑] 复杂度

正好 last - firstfproj 的应用。

[编辑] 可能的实现

template<InputIterator I, Sentinel<I> S, class Proj = ranges::identity,
         IndirectUnaryInvocable<ranges::projected<I, Proj>> Fun>
auto for_each(I first, S last, Fun f, Proj proj = Proj{}) 
    -> ranges::tagged_pair<tag::in(I), tag::fun(Fun)>
{
    for (; first != last; ++first)
        ranges::invoke(f, ranges::invoke(proj, *first));
    return {std::move(first), std::move(f)};
}

[编辑] 示例

[编辑] 参见

将函数应用于元素范围
(函数模板) [编辑]
range-for 循环(C++11) 在范围上执行循环[编辑]
将一元函数对象应用于来自范围的元素
(函数模板) [编辑]
将函数对象应用于序列的前 N 个元素
(函数模板) [编辑]