std::experimental::ranges::copy, std::experimental::ranges::copy_if
在头文件 <experimental/ranges/algorithm> 中定义 |
||
template< InputIterator I, Sentinel<I> S, WeaklyIncrementable O > requires IndirectlyCopyable<I, O> |
(1) | (范围 TS) |
template< InputRange R, WeaklyIncrementable O > requires IndirectlyCopyable<ranges::iterator_t<R>, O> |
(2) | (范围 TS) |
template< InputIterator I, Sentinel<I> S, WeaklyIncrementable O, class Proj = ranges::identity, |
(3) | (范围 TS) |
template< InputRange R, WeaklyIncrementable O, class Proj = ranges::identity, |
(4) | (范围 TS) |
将源范围 ([
first,
last)
或 r) 中的元素复制到从 result 开始的目标范围内,从源范围的第一个元素开始,一直到最后一个元素。
[
first,
last)
中的所有元素。对于每个非负整数 n < (last - first)
,执行 *(result + n) = *(first + n)。如果 result 在范围 [
first,
last)
内,则行为未定义。在这种情况下,可以使用 ranges::copy_backward 来代替。尽管上面描述了声明,但算法声明的实际模板参数数量和顺序未指定。因此,如果在调用算法时使用显式模板参数,程序可能无法移植。
内容 |
[编辑] 参数
first, last | - | 要复制的元素范围 |
r | - | 要复制的元素范围 |
result | - | 目标范围的起始位置 |
pred | - | 要应用于投影元素的谓词 |
proj | - | 要应用于元素的投影 |
[编辑] 返回值
包含以下两个成员的 tagged_pair
对象
- 第一个成员,带有标记
tag::in
,是源范围的末尾后迭代器(即类型为I
的迭代器,与哨兵 last 相等)。 - 第二个成员,带有标记
tag::out
,是结果范围的末尾后迭代器。
[编辑] 复杂度
[编辑] 可能的实现
第一个版本 |
---|
template<InputIterator I, Sentinel<I> S, WeaklyIncrementable O> requires IndirectlyCopyable<I, O>() ranges::tagged_pair<tag::in(I), tag::out(O)> copy(I first, S last, O result) { for (; first != last; ++first, (void)++result) *result = *first; return {first, result}; } |
第二个版本 |
template<InputRange R, WeaklyIncrementable O> requires IndirectlyCopyable<ranges::iterator_t<R>, O>() ranges::tagged_pair<tag::in(ranges::safe_iterator_t<R>), tag::out(O)> copy(R&& r, O result) { return ranges::copy(ranges::begin(r), ranges::end(r), result); } |
第三个版本 |
template<InputIterator I, Sentinel<I> S, WeaklyIncrementable O, class Proj = ranges::identity, IndirectUnaryPredicate<projected<I, Proj>> Pred> requires IndirectlyCopyable<I, O>() ranges::tagged_pair<tag::in(I), tag::out(O)> copy_if(I first, S last, O result, Pred pred, Proj proj = Proj{}) { for (; first != last; ++first) if (ranges::invoke(pred, ranges::invoke(proj, *first))) { *result = *first; ++result; } return {first, result}; } |
第四个版本 |
template<InputRange R, WeaklyIncrementable O, class Proj = ranges::identity, IndirectUnaryPredicate<projected<ranges::iterator_t<R>, Proj>> Pred> requires IndirectlyCopyable<ranges::iterator_t<R>, O>() ranges::tagged_pair<tag::in(ranges::safe_iterator_t<R>), tag::out(O)> copy_if(R&& r, O result, Pred pred, Proj proj = Proj{}) { return ranges::copy_if(ranges::begin(r), ranges::end(r), result, pred, proj); } |
[编辑] 示例
以下代码使用 copy 将一个向量的内容复制到另一个向量,并显示结果向量
#include <experimental/ranges/algorithm> #include <experimental/ranges/iterator> #include <iostream> #include <numeric> #include <vector> int main() { // see https://cppreference.cn/w/cpp/language/namespace_alias namespace ranges = std::experimental::ranges; std::vector<int> from_vector(10); std::iota(from_vector.begin(), from_vector.end(), 0); std::vector<int> to_vector; ranges::copy_if(from_vector.begin(), from_vector.end(), ranges::back_inserter(to_vector), [](const auto i) { return i % 3; }); // or, alternatively, // std::vector<int> to_vector(from_vector.size()); // std::copy(from_vector, to_vector.begin()); std::cout << "to_vector contains: "; ranges::copy(to_vector, ranges::ostream_iterator<int>(std::cout, " ")); std::cout << '\n'; }
输出
to_vector contains: 1 2 4 5 7 8
[编辑] 参见
(C++11) |
将元素范围复制到新位置 (函数模板) |
以反向顺序复制元素范围 (函数模板) | |
创建反转的范围副本 (函数模板) | |
将一定数量的元素复制到新位置 (函数模板) | |
将元素范围赋值为某个值 (函数模板) | |
复制元素范围,省略满足特定条件的元素 (函数模板) |