类型特性定义一个编译时基于模板的结构,以查询或修改类型的属性。
试图特化定义于
定义于
std::aligned_storage
template< std::size_t Len, std::size_t Align = /*default-alignment*/ > |
(C++11 起) |
提供嵌套类型 type
,其为平凡的标准布局类型,适于作为任何大小至多为 Len
且对齐要求为 Align
的因数的对象的未初始化存储。
Align
的默认值是任何大小至多为 Len
的对象的最强(最大)对齐要求。若不使用默认值,则 Align
对于某类型 T
必须为 alignof(T) 的值,否则行为未定义。
若 Len == 0 则行为未定义。
是否支持任何扩展对齐是实现定义的。
名称 | 定义 |
type |
长度至少为 Len 的 POD 类型,带对齐要求 Align |
template< std::size_t Len, std::size_t Align = /*default-alignment*/ > |
(C++14 起) |
std::aligned_storage<>::type
所定义的类型能用于创建适合保有给定类型对象的未初始化内存块,可选地对齐严格于其自然对齐要求,例如在缓存或页边界上。
同任何其他未初始化存储,对象通过使用布置 new 创建,并以显式的析构函数调用销毁。
除了默认实参, aligned_storage 能通过 alignas 表达:
template
struct aligned_storage {
struct type {
alignas(Align) unsigned char data[Len];
};
};
#include
#include
#include
template
class static_vector
{
// N 个 T 的正确对齐的未初始化存储
typename std::aligned_storage::type data[N];
std::size_t m_size = 0;
public:
// 于对齐存储创建对象
template void emplace_back(Args&&... args)
{
if (m_size >= N) // 可行的错误处理
throw std::bad_alloc{};
new (data + m_size) T(std::forward(args)...);
++m_size;
}
// 访问对齐存储中的对象
const T& operator[](std::size_t pos) const
{
// 注意: C++17 起需要 std::launder
return *reinterpret_cast(data + pos);
}
// 从对齐存储删除对象
~static_vector()
{
for (std::size_t pos = 0; pos < m_size; ++pos)
{
// 注意: C++17 起需要 std::launder
reinterpret_cast(data + pos)->~T();
}
}
};
int main()
{
static_vector v1;
v1.emplace_back(5, '*');
v1.emplace_back(10, '*');
std::cout << v1[0] << std::endl << v1[1] << std::endl;
return 0;
}
*****
**********