NoThrowForwardIt uninitialized_copy_n( InputIt first, Size count,
class Size, class NoThrowForwardIt >
NoThrowForwardIt uninitialized_copy_n( ExecutionPolicy&& policy,
ForwardIt first, Size count,
Copies
countelements from a range beginning at
firstto an uninitialized memory area beginning at
d_firstas if by
for (; count > 0; ++d_first, (void) ++first, --count)
::new (voidify
(*d_first))
typename std::iterator_traits<NoThrowForwardIt>::value_type(*first);
If an exception is thrown during the initialization, the objects already constructed are destroyed in an unspecified order.
2) Same as (1), but executed according to policy.
This overload participates in overload resolution only if all following conditions are satisfied:
If d_first +
[
â0â,
count)
overlaps with first +
[
â0â,
count)
, the behavior is undefined.
InputIt
must meet the requirements of LegacyInputIterator. -ForwardIt
must meet the requirements of LegacyForwardIterator. -NoThrowForwardIt
must meet the requirements of LegacyForwardIterator. -No increment, assignment, comparison, or indirection through valid instances of NoThrowForwardIt
may throw exceptions. [edit] Return value
Iterator to the element past the last element copied.
[edit] ComplexityLinear in count.
[edit] ExceptionsThe overload with a template parameter named ExecutionPolicy
reports errors as follows:
ExecutionPolicy
is one of the standard policies, std::terminate is called. For any other ExecutionPolicy
, the behavior is implementation-defined.template<class InputIt, class Size, class NoThrowForwardIt> constexpr NoThrowForwardIt uninitialized_copy_n(InputIt first, Size count, NoThrowForwardIt d_first) { using T = typename std::iterator_traits<NoThrowForwardIt>::value_type; NoThrowForwardIt current = d_first; try { for (; count > 0; ++first, (void) ++current, --count) ::new (static_cast<void*>(std::addressof(*current))) T(*first); } catch (...) { for (; d_first != current; ++d_first) d_first->~T(); throw; } return current; }[edit] Example [edit] Defect reports
The following behavior-changing defect reports were applied retroactively to previously published C++ standards.
DR Applied to Behavior as published Correct behavior LWG 2133 C++98 the effect description used a for loop with the iterationRetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4