为什么我不能用reset()删除unique_ptr <char []>?

时间:2016-10-21 10:26:27

标签: c++ c++11 c++builder unique-ptr

当我有一个指向单个对象的唯一指针时,我可以使用reset()删除它:

std::unique_ptr<char> variable(new char);
variable.reset();

但是,这对包含数组的std::unique_ptr不起作用。为什么?删除这样的指针的正确方法是什么?

我正在使用Embarcadero C ++ Builder 10.1。相关标准是C ++ 11。

我的观察

当我有一个包含数组的唯一指针时,无法编译:

std::unique_ptr<char[]> variable(new char[10]);
variable.reset();

错误讯息为no matching function to call for 'reset'

这也失败了:

std::unique_ptr<char[]> variable(new char[10]);
variable.reset(nullptr);

错误讯息为cannot initialize a variable of type 'pointer' (aka 'char *') with an lvalue of type '<bound member function type>'assigning to '<bound member function type>' from incompatible type '_Null_ptr_type' (aka 'nullptr_t')

编译:

std::unique_ptr<char[]> variable(new char[10]);
variable = nullptr;

来自&lt; memory&gt;

的相关代码
template<class _Uty>
using _Enable_ctor_reset = enable_if_t<
    is_same<_Uty, pointer>::value
    || (is_same<pointer, element_type *>::value
    && is_pointer<_Uty>::value
    && is_convertible<
        remove_pointer_t<_Uty>(*)[],
        element_type(*)[]
    >::value)>;

_Myt& operator=(_Null_ptr_type) _NOEXCEPT
    {   // assign a null pointer
    reset(pointer());
    return (*this);
    }

_NOINLINE void reset(_Null_ptr_type _Ptr) _NOEXCEPT
    {   // establish new null pointer
    pointer _Old = this->_Myptr;
    this->_Myptr = _Ptr;
    if (_Old != pointer())
        this->get_deleter()(_Old);
    }

template<class _Uty,
    class = _Enable_ctor_reset<_Uty> >
void reset(_Uty _Ptr) _NOEXCEPT
    {   // establish new pointer
    pointer _Old = get();
    this->_Myptr() = _Ptr;
    if (_Old != pointer())
        this->get_deleter()(_Old);
    }

1 个答案:

答案 0 :(得分:1)

这似乎是标准库中的一个错误,因为相同的代码会与其他编译器一起编译,正如评论中deW1sanjay所指出的那样。

C ++ 11标准,第20.7.1.3节(“具有运行时长度的数组对象的unique_ptr)列出reset()具有以下签名:

  

void reset(指针p =指针())noexcept;

第一个示例无法编译,因为标准库实现中缺少默认参数。第二个示例基本上调用reset(pointer()),无法编译。可能这个编译错误是没有添加默认参数的原因。

我向Embarcadero做了一个错误报告:

RSP-16165 Compile error when calling reset() on unique_ptr containing array object