std::copy_n
科技促进发展:复制[医]n
Defined in header | | |
---|---|---|
template< class InputIt, class Size, class OutputIt > OutputIt copy_n( InputIt first, Size count, OutputIt result | (1) | (since C++11) |
template< class ExecutionPolicy, class ForwardIt1, class Size, class ForwardIt2 > ForwardIt2 copy_n( ExecutionPolicy&& policy, ForwardIt1 first, Size count, ForwardIt2 result | (2) | (since C++17) |
1%份29份count值开始的范围。first从result,如果count>0.做其他的事。
2%29与%281%29相同,但根据policy。此重载只参与以下情况下的过载解决方案:std::is_execution_policy_v<std::decay_t<ExecutionPolicy>>是真的
参数
first | - | the beginning of the range of elements to copy from |
---|---|---|
count | - | number of the elements to copy |
result | - | the beginning of the destination range |
policy | - | the execution policy to use. See execution policy for details. |
类型要求
-输入必须符合输入器的要求。
-输出必须符合输出器的要求。
-前进1,前进2必须符合先行者的要求。
返回值
目标区域中的Iterator,指向最后一个复制的元素,如果count>0或result否则。
复杂性
一点儿没错count任务,如果count>0...
例外
带有名为ExecutionPolicy
报告错误如下:
- 如果执行作为算法一部分调用的函数,则引发异常
ExecutionPolicy
是其中之一标准政策,,,std::terminate
叫做。对于任何其他人ExecutionPolicy
,行为是由实现定义的。
- 如果算法不能分配内存,
std::bad_alloc
被扔了。
可能的实施
模板<类输入,类大小,类输出它>输出它复制[医]n%28 InputIt First,Size Count,OutputIt结果%29{if%28 count>0%29{%2A结果++=%2A首先;对于%28 Size i=1;i<count;++i%29{%2A结果++=%2A++优先;}返回结果;}
*。
例
二次
#include <iostream>
#include <string>
#include <algorithm>
#include <iterator>
int main()
{
std::string in = "1234567890";
std::string out;
std::copy_n(in.begin(), 4, std::back_inserter(out)
std::cout << out << '\n';
}
二次
产出:
二次
1234
二次
另见
copycopy_if (C++11) | copies a range of elements to a new location (function template) |
---|
© cppreference.com
在CreativeCommonsAttribution下授权-ShareAlike未移植许可v3.0。