gpt4 book ai didi

c++ - 提供(空的)用户定义的析构函数会导致编译错误

转载 作者:塔克拉玛干 更新时间:2023-11-02 23:06:21 25 4
gpt4 key购买 nike

当我没有用户定义的析构函数时(在 GCC 4.7.2 上)编译得很好的代码,即使提供了一个用户定义的析构函数也会产生错误:

#include <memory>

class Test
{
std::unique_ptr<int> val;
};

template <typename Type>
class B
{
public:
//destructor:
// if I comment this out, the code compiles just fine:
~B() { }

private:
Test a;
};

int main()
{
auto s = B<int>();
}

未注释掉析构函数时产生的错误的重点是:

  • Test 的复制构造函数不存在,并且不是隐式创建的,因为它的格式不正确
  • 有人试图为 unique_ptr 使用已删除的复制构造函数。

对于任何感兴趣的人,完整的错误输出位于本文的底部。

我知道 unique_ptr 不能复制构造(除非参数是右值),因此编译器不可能为类生成有效的隐式复制构造函数 测试

我不明白的是为什么即使定义一个 析构函数也会突然需要这些复制工具。显然,当使用 unique_ptr 之类的东西时,这是不可能提供的。

谁能告诉我为什么会这样?

未注释掉析构函数时的完整错误输出:

In file included from /usr/include/c++/4.7/list:64:0,
from ../../Dropbox/Programming/C++/test/main.cpp:2:
/usr/include/c++/4.7/bits/stl_list.h: In instantiation of 'std::_List_node<_Tp>::_List_node(_Args&& ...) [with _Args = {const Test&}; _Tp = Test]':
/usr/include/c++/4.7/ext/new_allocator.h:110:4: required from 'void __gnu_cxx::new_allocator<_Tp>::construct(_Up*, _Args&& ...) [with _Up = std::_List_node<Test>; _Args = {const Test&}; _Tp = std::_List_node<Test>]'
/usr/include/c++/4.7/bits/stl_list.h:503:8: required from 'std::list<_Tp, _Alloc>::_Node* std::list<_Tp, _Alloc>::_M_create_node(_Args&& ...) [with _Args = {const Test&}; _Tp = Test; _Alloc = std::allocator<Test>; std::list<_Tp, _Alloc>::_Node = std::_List_node<Test>]'
/usr/include/c++/4.7/bits/stl_list.h:1533:63: required from 'void std::list<_Tp, _Alloc>::_M_insert(std::list<_Tp, _Alloc>::iterator, _Args&& ...) [with _Args = {const Test&}; _Tp = Test; _Alloc = std::allocator<Test>; std::list<_Tp, _Alloc>::iterator = std::_List_iterator<Test>]'
/usr/include/c++/4.7/bits/stl_list.h:997:9: required from 'void std::list<_Tp, _Alloc>::push_back(const value_type&) [with _Tp = Test; _Alloc = std::allocator<Test>; std::list<_Tp, _Alloc>::value_type = Test]'
/usr/include/c++/4.7/bits/stl_list.h:1466:6: required from 'void std::list<_Tp, _Alloc>::_M_initialize_dispatch(_InputIterator, _InputIterator, std::__false_type) [with _InputIterator = std::_List_const_iterator<Test>; _Tp = Test; _Alloc = std::allocator<Test>]'
/usr/include/c++/4.7/bits/stl_list.h:582:9: required from 'std::list<_Tp, _Alloc>::list(const std::list<_Tp, _Alloc>&) [with _Tp = Test; _Alloc = std::allocator<Test>; std::list<_Tp, _Alloc> = std::list<Test>]'
../../Dropbox/Programming/C++/test/main.cpp:11:7: required from here
/usr/include/c++/4.7/bits/stl_list.h:115:71: error: use of deleted function 'Test::Test(const Test&)'
../../Dropbox/Programming/C++/test/main.cpp:5:7: note: 'Test::Test(const Test&)' is implicitly deleted because the default definition would be ill-formed:
../../Dropbox/Programming/C++/test/main.cpp:5:7: error: use of deleted function 'std::unique_ptr<_Tp, _Dp>::unique_ptr(const std::unique_ptr<_Tp, _Dp>&) [with _Tp = int; _Dp = std::default_delete<int>; std::unique_ptr<_Tp, _Dp> = std::unique_ptr<int>]'
In file included from /usr/include/c++/4.7/memory:86:0,
from ../../Dropbox/Programming/C++/test/main.cpp:3:
/usr/include/c++/4.7/bits/unique_ptr.h:262:7: error: declared here

最佳答案

如果你定义~B(),这会抑制B的移动构造函数,所以编译器会尝试生成一个复制构造函数但失败了,因为unique_ptr 不可复制构造。

如果省略~B(),则生成B的移动构造函数并在main中使用。

您可以请求自动生成的移动构造函数:

B(B &&) = default;

这是与 C++03 代码向后兼容的标准中的一个特性;根据三原则,编写自己的析构函数(等)的代码被假定为管理自己的资源,因此除非明确请求,否则自动生成移动构造函数是不合适的。

关于c++ - 提供(空的)用户定义的析构函数会导致编译错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16192865/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com