allocator_traits :: construct()vs allocator_traits :: allocate()

时间:2013-07-25 16:59:27

标签: c++ memory-management c++11

C ++ 11提供std::allocator_traits类作为使用分配器的标准方法。静态函数std::allocator_traits::construct()指针带到应该构造对象的位置。然而,std::allocator_traits::allocate()静态函数返回一个allocator::pointer值,它只需要像指针一样,但它不一定是一个(通常,虽然std::allocator::pointer需要是一个指针)。

一般来说,如果它们可以使用不兼容的类型,那么应该如何使用分配和构造静态方法?只有当pointer类型实际上可以转换为普通的普通指针时才可以使用它们吗?

2 个答案:

答案 0 :(得分:6)

根据您目前的情况,有两种方法可以做到这一点。

如果你有一个左值表达式,比如节点中的值字段,那么你可以像这样使用std :: addressof:

allocator_traits<allocator_type>::construct(alloc, std::addressof(ptr->value), ...);

其中ptrallocator_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