std::uninitialized_value_construct_n
STD::未初始化[医]价值[医]构造[医]n
Defined in header | | |
---|---|---|
template< class ForwardIt, class Size > ForwardIt uninitialized_value_construct_n( ForwardIt first, Size n | (1) | (since C++17) |
template< class ExecutionPolicy, class ForwardIt, class Size > ForwardIt uninitialized_value_construct_n( ExecutionPolicy&& policy, ForwardIt first, Size n | (2) | (since C++17) |
1%29构造n类型对象typename iterator_traits<ForwardIt>::value_type在未初始化的存储中,从first通过值初始化,好像
二次
for (; n > 0; (void) ++first, --n)
::new (static_cast<void*>(std::addressof(*first)))
typename std::iterator_traits<ForwardIt>::value_type(
二次
如果在初始化期间抛出异常,则该函数没有任何效果。
2%29与%281%29相同,但根据policy此重载不参与过载解决,除非std::is_execution_policy_v<std::decay_t<ExecutionPolicy>>是真的
参数
first | - | the beginning of the range of elements to initialize |
---|---|---|
n | - | the number of elements to initialize |
policy | - | the execution policy to use. See execution policy for details. |
类型要求
---。
-不通过有效的Forward实例进行增量、赋值、比较或间接转换,否则会引发异常。
返回值
对象范围的末尾为%28i。e.std::next
(first, n)
29%。
复杂性
线性在n
...
例外
带有名为ExecutionPolicy
报告错误如下:
- 如果执行作为算法一部分调用的函数,则引发异常
ExecutionPolicy
是其中之一标准政策,,,std::terminate
叫做。对于任何其他人ExecutionPolicy
,行为是由实现定义的。
- 如果算法不能分配内存,
std::bad_alloc
被扔了。
可能的实施
模板<类向前,类大小>未初始化[医]价值[医]构造[医]n%28 ForwardIt First,大小n%29{tyUdef type Name std::iterator[医]性状<ForwardIt>*价值[医]类型值;前进当前=先;尝试{%28;n>0;%28void%29++当前,-n%29{::新的%28静态[医]铸造<空隙%2A>%28 std::地址%28%2A当前%29%29%29值%28%29}返回电流}捕获%28%29%29{%28;第1%21=当前;++第29%{第一->值%28%29;}丢弃;}}
*。
例
另见
uninitialized_value_construct (C++17) | constructs objects by value-initialization in an uninitialized area of memory, defined by a range (function template) |
---|---|
uninitialized_default_construct_n (C++17) | constructs objects by default-initialization in an uninitialized area of memory, defined by a start and a count (function template) |
© cppreference.com
在CreativeCommonsAttribution下授权-ShareAlike未移植许可v3.0。
http://en.cpPreference.com/w/cpp/Memory/uninitiated[医]价值[医]构造[医]n