最終更新日時(UTC):
が更新

履歴 編集

function
<stacktrace>

std::basic_stacktrace::コンストラクタ(C++23)

basic_stacktrace()
  noexcept(is_nothrow_default_constructible_v<allocator_type>);  // (1) C++23

explicit basic_stacktrace(const allocator_type& alloc) noexcept; // (2) C++23

basic_stacktrace(const basic_stacktrace& other);                 // (3) C++23
basic_stacktrace(basic_stacktrace&& other) noexcept;             // (4) C++23

basic_stacktrace(const basic_stacktrace& other,
                 const allocator_type& alloc);                   // (5) C++23
basic_stacktrace(basic_stacktrace&& other,
                 const allocator_type& alloc);                   // (6) C++23

概要

basic_stacktraceオブジェクトを構築する。

  • (1) : デフォルト構築
  • (2) : アロケータを指定して構築
  • (3) : コピー構築
  • (4) : ムーブ構築
  • (5) : アロケータを指定してコピー構築
  • (6) : アロケータを指定してムーブ構築

効果

  • (2) : 保持するstd::vector<std::stacktrace_entry>型スタックトレースの履歴のオブジェクトに、コンストラクタ引数としてallocを渡す

事後条件

  • (1), (2) : empty()trueになること

例外

  • (3), (4), (5), (6) : 実装は、メモリ確保に失敗した場合にempty()trueにすることで例外仕様を強化できる

備考

  • 実装は、これらのコンストラクタのほかに、current()関数によるスタックトレース履歴を保持するための追加のコンストラクタをもっている可能性がある

#include <cassert>
#include <stacktrace>

void g() {
  // (1) デフォルト構築
  std::stacktrace st1{};
  assert(st1.empty());

  // (2) アロケータを指定して構築
  std::allocator<std::stacktrace_entry> alloc{};
  std::stacktrace st2{alloc};
  assert(st2.empty());

  // (3) コピー構築
  std::stacktrace st3 = st1;
  assert(st3 == st1);

  // (4) ムーブ構築
  std::stacktrace st4 = std::move(st3);
  assert(st4 == st1);

  // (5) アロケータを指定してコピー構築
  std::stacktrace st5{st1, alloc};
  assert(st5 == st1); // アロケータは比較されない

  // (6) アロケータを指定してムーブ構築
  std::stacktrace st6{std::move(st5), alloc};
  assert(st6 == st1);
}

void f() {
  g();
}

int main() {
  f();
}

出力

バージョン

言語

  • C++23

処理系