Skip to content

Latest commit

 

History

History
115 lines (89 loc) · 3.07 KB

uninitialized_value_construct.md

File metadata and controls

115 lines (89 loc) · 3.07 KB

uninitialized_value_construct

  • memory[meta header]
  • std[meta namespace]
  • function template[meta id-type]
  • cpp17[meta cpp]
namespace std {
  template <class ForwardIterator>
  void
    uninitialized_value_construct(ForwardIterator first,
                                  ForwardIterator last); // (1) C++17
  template <class ForwardIterator>
  constexpr void
    uninitialized_value_construct(ForwardIterator first,
                                  ForwardIterator last); // (1) C++26

  template <class ExecutionPolicy, class ForwardIterator>
  void
    uninitialized_value_construct(ExecutionPolicy&& exec,
                                  ForwardIterator first,
                                  ForwardIterator last); // (2) C++17
}

概要

未初期化領域の範囲の各要素を値構築する。

未初期化領域の入力イテレータ範囲[first, last)の各要素を値構築する (ゼロ初期化する)。

効果

以下と等価:

for (; first != last; ++first)
  ::new (static_cast<void*>(addressof(*first)))
    typename iterator_traits<ForwardIterator>::value_type();
  • addressof[link addressof.md]
  • iterator_traits[link /reference/iterator/iterator_traits.md]

戻り値

なし

例外

呼び出すコンストラクタなどから例外がスローされた場合、その例外がこの関数の外側に伝播される前に、その時点で構築済のオブジェクトは全て未規定の順序で破棄される。すなわち、例外がスローされた場合は初期化対象領域は未初期化のままとなる。

#include <iostream>
#include <memory>

struct Vector {
  int x, y;
};

int main()
{
  std::allocator<Vector> alloc;

  // メモリ確保。
  // この段階では、[p, p + size)の領域は未初期化
  const std::size_t size = 3;
  Vector* p = alloc.allocate(size);

  // 未初期化領域[p, p + size)を値構築
  std::uninitialized_value_construct(p, p + size);

  // 各要素を出力
  for (std::size_t i = 0; i < size; ++i) {
    const Vector& v = *(p + i);
    std::cout << v.x << ',' << v.y << std::endl;
  }

  // オブジェクトを破棄
  std::destroy(p, p + size);

  // メモリ解放
  alloc.deallocate(p, size);
}
  • std::uninitialized_value_construct[color ff0000]
  • std::allocator[link allocator.md]
  • alloc.allocate[link allocator/allocate.md]
  • alloc.deallocate[link allocator/deallocate.md]
  • std::destroy[link destroy.md]

出力

0,0
0,0
0,0

バージョン

言語

  • C++17

処理系

関連項目

参照