C ++ 11提供std::allocator_traits
类作为使用分配器的标准方法。静态函数std::allocator_traits::construct()
将指针带到应该构造对象的位置。然而,std::allocator_traits::allocate()
静态函数返回一个allocator::pointer
值,它只需要像指针一样,但它不一定是一个(通常,虽然std::allocator::pointer
需要是一个指针)。
一般来说,如果它们可以使用不兼容的类型,那么应该如何使用分配和构造静态方法?只有当pointer
类型实际上可以转换为普通的普通指针时才可以使用它们吗?
答案 0 :(得分:6)
根据您目前的情况,有两种方法可以做到这一点。
如果你有一个左值表达式,比如节点中的值字段,那么你可以像这样使用std :: addressof:
allocator_traits<allocator_type>::construct(alloc, std::addressof(ptr->value), ...);
其中ptr
是allocator_type::pointer
。
但是,如果您没有要取消引用的字段,并且想要将allocator_type::pointer
转换为T*
,那么首先需要先实现一个技巧:
template <class T>
inline
T*
to_raw_pointer(T* p) noexcept
{
return p;
}
template <class Pointer>
inline
typename std::pointer_traits<Pointer>::element_type*
to_raw_pointer(Pointer p) noexcept
{
return p != nullptr ? ::to_raw_pointer(p.operator->())
: nullptr;
}
现在你可以说:
allocator_traits<allocator_type>::construct(alloc, to_raw_pointer(ptr), ...);
答案 1 :(得分:1)
从C ++ 20开始,std::to_address
中提出了P0653。