首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

调用`std::unique_ptr` move构造函数时“使用已删除的函数”?

问题分析

当你在调用 std::unique_ptr 的 move 构造函数时遇到“使用已删除的函数”错误,通常是因为以下几个原因之一:

  1. 自定义删除器:如果你为 std::unique_ptr 提供了自定义删除器,而这个删除器没有正确实现移动语义。
  2. 不可移动类型std::unique_ptr 所指向的对象类型本身是不可移动的。
  3. 移动构造函数被删除std::unique_ptr 所指向的对象类型的移动构造函数被显式删除。

原因及解决方法

1. 自定义删除器

如果你使用了自定义删除器,确保删除器也支持移动语义。例如:

代码语言:txt
复制
#include <iostream>
#include <memory>

struct CustomDeleter {
    void operator()(int* ptr) const {
        std::cout << "Deleting pointer" << std::endl;
        delete ptr;
    }

    // 确保删除器支持移动语义
    CustomDeleter(CustomDeleter&&) = default;
    CustomDeleter& operator=(CustomDeleter&&) = default;
};

int main() {
    std::unique_ptr<int, CustomDeleter> ptr1(new int(42));
    std::unique_ptr<int, CustomDeleter> ptr2(std::move(ptr1));
    return 0;
}

2. 不可移动类型

确保 std::unique_ptr 所指向的对象类型是可移动的。例如:

代码语言:txt
复制
#include <iostream>
#include <memory>

struct NonMovable {
    NonMovable() = default;
    ~NonMovable() = default;

    // 禁止移动构造函数和移动赋值操作符
    NonMovable(NonMovable&&) = delete;
    NonMovable& operator=(NonMovable&&) = delete;
};

int main() {
    // 这将导致编译错误,因为 NonMovable 是不可移动的
    std::unique_ptr<NonMovable> ptr1(new NonMovable);
    std::unique_ptr<NonMovable> ptr2(std::move(ptr1));
    return 0;
}

3. 移动构造函数被删除

确保 std::unique_ptr 所指向的对象类型的移动构造函数没有被显式删除。例如:

代码语言:txt
复制
#include <iostream>
#include <memory>

struct Movable {
    Movable() = default;
    ~Movable() = default;

    // 确保移动构造函数没有被删除
    Movable(Movable&&) = default;
    Movable& operator=(Movable&&) = default;
};

int main() {
    std::unique_ptr<Movable> ptr1(new Movable);
    std::unique_ptr<Movable> ptr2(std::move(ptr1));
    return 0;
}

总结

  • 自定义删除器:确保删除器支持移动语义。
  • 不可移动类型:确保 std::unique_ptr 所指向的对象类型是可移动的。
  • 移动构造函数被删除:确保 std::unique_ptr 所指向的对象类型的移动构造函数没有被显式删除。

通过以上方法,你应该能够解决调用 std::unique_ptr move 构造函数时“使用已删除的函数”的问题。

参考链接

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • 详解 C++ 11 中的智能指针

    C/C++ 语言最为人所诟病的特性之一就是存在内存泄露问题,因此后来的大多数语言都提供了内置内存分配与释放功能,有的甚至干脆对语言的使用者屏蔽了内存指针这一概念。这里不置贬褒,手动分配内存与手动释放内存有利也有弊,自动分配内存和自动释放内存亦如此,这是两种不同的设计哲学。有人认为,内存如此重要的东西怎么能放心交给用户去管理呢?而另外一些人则认为,内存如此重要的东西怎么能放心交给系统去管理呢?在 C/C++ 语言中,内存泄露的问题一直困扰着广大的开发者,因此各类库和工具的一直在努力尝试各种方法去检测和避免内存泄露,如 boost,智能指针技术应运而生。

    03
    领券