简单实现std::shared_ptr

下面是一个简化版的shared_ptr实现,仅包含基本的引用计数和内存释放功能:

template <typename T>
class SharedPtr {
public:
    SharedPtr(T* ptr = nullptr) 
        : m_ptr(ptr), 
        m_refCount(new int(1)), 
        m_isArray(false) {}
    ~SharedPtr() {
        release();
    }


    SharedPtr(const SharedPtr& other) 
        : m_ptr(other.m_ptr),
        m_refCount(other.m_refCount),                 
        m_isArray(other.m_isArray) {
        (*m_refCount)++;
    }


    SharedPtr& operator=(const SharedPtr& other) {
        if (this != &other) {
            release();
            m_ptr = other.m_ptr;
            m_refCount = other.m_refCount;
            m_isArray = other.m_isArray;
            (*m_refCount)++;
        }
        return *this;
    }


    T& operator*() const {
        return *m_ptr;
    }


    T* operator->() const {
        return m_ptr;
    }


private:
    void release() {
        (*m_refCount)--;
        if (*m_refCount == 0) {
            if (m_isArray) {
                delete[] m_ptr;
            } else {
                delete m_ptr;
            }

            delete m_refCount;
        }
    }


    T* m_ptr;
    int* m_refCount;
    bool m_isArray;
};

 

上述代码实现了一个简化版的SharedPtr模板类,用于管理动态内存。它包含一个指向动态内存的指针m_ptr和一个引用计数的指针m_refCount。引用计数使用int*类型表示,以便记录有多少个SharedPtr对象共享同一个指针。

在构造函数中,我们初始化指针和引用计数。在析构函数中,我们释放动态内存。在拷贝构造函数和赋值运算符中,我们更新引用计数,并确保正确处理自赋值的情况。

此外,我们还重载了*->运算符,以便可以像使用指针一样访问SharedPtr对象所管理的动态内存。

需要注意的是,上述代码仅为简化版实现,没有处理多线程安全性、自定义删除器等复杂的情况。实际上,std::shared_ptr的实现要比上述代码复杂得多,涉及到更多的细节和考虑。因此,如果需要使用shared_ptr,建议使用标准库提供的std::shared_ptr,而不是自己实现。

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值