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

blu*_*rni 10 c++ memory-management c++11

C++ 11提供了std::allocator_traits类作为使用分配器的标准方法.static函数std::allocator_traits::construct()接受指向对象构造位置的指针.的std::allocator_traits::allocate()静态功能,但是,返回一个allocator::pointer值,该值仅必须表现得像一个指针,但它不一定是一个(通常,虽然std::allocator::pointer需要是一个指针).

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

How*_*ant 7

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

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

allocator_traits<allocator_type>::construct(alloc, std::addressof(ptr->value), ...);
Run Code Online (Sandbox Code Playgroud)

这里ptr是一个allocator_type::pointer.

但是,如果您没有要取消引用的字段并且想要转换allocator_type::pointerT*,则需要先实现一个技巧:

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;
}
Run Code Online (Sandbox Code Playgroud)

现在你可以说:

allocator_traits<allocator_type>::construct(alloc, to_raw_pointer(ptr), ...);
Run Code Online (Sandbox Code Playgroud)

  • 我认为查找只会发现第二次重载是偏执狂,但在测试中我发现它根本不需要.在编写成员交换时我偶尔会偶然发现这样的问题,因此除非我真的希望ADL接管,否则他们会养成一直排他性的习惯. (4认同)