std::basic_stacktrace<Allocator>::basic_stacktrace
来自cppreference.com
< cpp | utility | basic stacktrace
basic_stacktrace() noexcept(/* see below */); |
(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
,或从 other
复制/移动。
1) 默认构造函数。构造带默认构造的分配器的空
basic_stacktrace
。2) 以
alloc
为分配器构造空 basic_stacktrace
。3) 复制构造函数。以
other
的内容副本构造 basic_stacktrace
,如同通过调用 std::allocator_traits<allocator_type>::select_on_container_copy_construction(other.get_allocator()) 获得分配器。4) 移动构造函数。用移动语义以
other
的内容构造 basic_stacktrace
。从 other
的分配器移动构造分配器。构造后, other
被置于合法但未指定的状态。5) 同复制构造函数,除了以
alloc
为分配器。6) 若 alloc == other.get_allocator() 则表现同移动构造函数。否则,用
alloc
分配内存并进行逐元素移动。以 alloc
为分配器。(3,5,6) 在分配失败时可能抛出异常或构造空的 basic_stacktrace
。
参数
alloc | - | 用于构造的 basic_stacktrace 的所有内存分配的分配器
|
other | - | 要复制/移动的另一 basic_stacktrace
|
异常
1)
noexcept 说明:
noexcept(std::is_nothrow_default_constructible_v<allocator_type>)
3,5,6) 可能传播分配失败时抛出的异常。
复杂度
1-2) 常数。
3) 与
other
的大小成线性。4) 常数。
5) 与
other
的大小成线性。6) 若 alloc != other.get_allocator() 则与
other
的大小成线性,否则为常数。注解
在容器移动构造(重载 (4))后,指向 other 的引用及迭代器(除了尾迭代器)保持合法,但指代现于 *this 中的元素。当前标准由 [container.requirements.general]/12 中的总括陈述作出此保证,而 LWG 问题 2321 正在考虑更严格的保证。
示例
本节未完成 原因:暂无示例 |
参阅
赋值给 basic_stacktrace (公开成员函数) | |
[静态] |
获得当前栈踪或其给定部分 (公开静态成员函数) |