手动实现shared_ptr

本文详细介绍了如何手动实现一个模板化的智能指针类,包括构造函数、拷贝构造函数、赋值构造函数和析构函数。智能指针用于管理动态分配的内存,通过引用计数来决定何时释放资源,防止内存泄漏。此外,还提供了获取值和引用计数的方法。
摘要由CSDN通过智能技术生成

手动实现范例:

template <class T> 
class MyPointer {
public:
    //普通构造函数, 设定T * ptr的值,并将引用计数设为1
    MyPointer(T * ptr) {
        ref = ptr;
        ref_count = new unsigned;
        *ref_count = 1;
    }

	//copy construct;
    MyPointer(MyPointer<T> &sptr) {
        ref = sptr.ref;
        ref_count = sptr.ref_count;
        ++(*ref_count);
    }

	//rewrite construct;
    MyPointer<T> & operator = (MyPointer<T> &sptr) {
        //同一个指针,直接返回
        if (this == &sptr)
            return *this;

        //如果计数值大于1,则旧指针计数值-1
        if(*ref_count > 0)
            remove();

        //把旧指针值给新指针
        ref = sptr.ref;
        ref_count = sptr.ref_count;

        //指针计数+1
        ++(*ref_count);
        return *this;
    }
    //deconstruct;
    ~MyPointer() {
        remove();
    }

    T getValue() {
        return *ref;
    }

    T getCount() {
        return static_cast<T>(*ref_count);
    }
protected:
    //delete ref;
    void remove() {
        --(*ref_count);

        //如果ref_count等于0,则销毁指针,并执行析构函数
        if (*ref_count == 0) {
            delete ref;
            delete ref_count;
            ref = NULL;
            ref_count = NULL;
        }
    }
private:
    unsigned * ref_count;    //应用计数值
    T * ref;                 //普通指针
};
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
shared_ptr是C++中的智能指针,用于管理动态分配的对象。它通过引用计数的方式跟踪指向对象的所有shared_ptr,并在引用计数为零时自动释放内存。下面是一个简单的示例,展示了如何使用shared_ptr: ```cpp #include <iostream> #include <memory> int main() { // 创建一个动态分配的整数对象 std::shared_ptr<int> ptr(new int(42)); // 使用shared_ptr访问对象 std::cout << "Value: " << *ptr << std::endl; std::cout << "Address: " << ptr.get() << std::endl; // 创建一个新的shared_ptr来共享同一个对象 std::shared_ptr<int> ptr2 = ptr; // 输出引用计数 std::cout << "Reference count: " << ptr.use_count() << std::endl; // 修改共享对象的值 *ptr = 100; // 输出新的值 std::cout << "New value: " << *ptr2 << std::endl; // 手动释放一个shared_ptr ptr.reset(); // 输出引用计数(为1,因为ptr已释放) std::cout << "Reference count: " << ptr2.use_count() << std::endl; return 0; } ``` 在这个示例中,我们创建了一个动态分配的整数对象,并使用shared_ptr进行管理。然后,我们创建了另一个shared_ptr来共享同一个对象。无论哪个shared_ptr被释放,只要仍有其他shared_ptr引用该对象,内存就不会被释放。通过use_count()函数,我们可以获得当前对象的引用计数。 值得注意的是,shared_ptr使用引用计数,这意味着如果存在循环引用(即两个或多个shared_ptr相互引用),对象可能不会被正确释放,从而导致内存泄漏。为了避免这种情况,可以使用weak_ptr来解决循环引用问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值