C++之unique_ptr

unique_ptr 为独占的智能指针,与所指对象的内存绑定紧密,不能与其他unique_ptr类型的指针对象共享所指对象的内存。比如

    unique_ptr<TEST> p1(new TEST("case_1"));
    auto p44 = p1;

 编译是不能通过的。可以通过move来转移内存

    unique_ptr<TEST> p1(new TEST("case_1"));
    auto p44 = move(p1);

断点调试一下

 继续往下

 我们可以发现 p44指向的地址变成了p1开始指向的地址,而p1的地址变成了0x0.

另外通过release函数也可以实现转移

 

*************************内存又是如何释放的呢?*********************

举个例子

class TEST
{
public:
    TEST(const string & name)
        :_name(name)
    {
        cout<<"TEST:"<<_name<<endl;}

    ~TEST()
    {
        cout<<"~TEST:"<<_name<<endl;
    }

//private:
    string _name;
};
int  main()
{
    unique_ptr<TEST> p1(new TEST("case_1"));
    unique_ptr<TEST> p2(p1.release());          //!将所有权从p1转移到p2,p1现在指向NULL。
    cout<<"++++++++++++++++++++++++"<<endl;
    unique_ptr<TEST> p3(new TEST("case_2"));
    p2.reset(p3.release());                     //!p2释放了原来指向的内存,接受了p3指向的内存。
 
	return 0;
}

输出结果如下:

 case1被自动释放了,应为p2被赋予了其他值。

 

unique_ptrC++11 标准提供的智能指针,用于管理动态分配的对象。它使用了独占所有权的概念,保证了在不再需要指针时自动释放资源,从而避免了内存泄漏。 手撕 unique_ptr 的实现涉及到指针的拷贝和移动语义。下面是一个简单的手撕 unique_ptr 的示例代码: ```cpp template <typename T> class unique_ptr { public: explicit unique_ptr(T* ptr = nullptr) : ptr_(ptr) {} ~unique_ptr() { delete ptr_; } unique_ptr(const unique_ptr&) = delete; // 禁用拷贝构造函数 unique_ptr& operator=(const unique_ptr&) = delete; // 禁用拷贝赋值运算符 unique_ptr(unique_ptr&& other) noexcept : ptr_(other.ptr_) { other.ptr_ = nullptr; } unique_ptr& operator=(unique_ptr&& other) noexcept { if (this != &other) { delete ptr_; ptr_ = other.ptr_; other.ptr_ = nullptr; } return *this; } T& operator*() const { return *ptr_; } T* operator->() const { return ptr_; } T* get() const { return ptr_; } private: T* ptr_; }; ``` 上述代码中,我们定义了一个类模板 `unique_ptr`,它模拟了标准库中的 `std::unique_ptr` 功能。在构造函数中,我们接受一个指针作为参数,并将其保存在 `ptr_` 成员变量中。析构函数负责释放指针所指向的资源。为了遵循独占所有权的原则,我们禁用了拷贝构造函数和拷贝赋值运算符,而使用移动语义来实现赋值操作。`operator*` 和 `operator->` 用于重载解引用操作符,方便使用指针指向的对象。 需要注意的是,上述实现只是一个简单的手撕版 unique_ptr,并没有处理更复杂的边界情况和异常安全性。在实际使用中,建议使用标准库提供的 `std::unique_ptr`,它已经经过了充分测试和优化。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值