C++ 智能指针(unique_ptr, shared_ptr)的源码分析

本文深入分析了C++智能指针unique_ptr和shared_ptr的源码实现,包括它们的构造函数、拷贝与赋值操作、析构函数以及release方法。特别指出shared_ptr在拷贝和赋值时如何更新引用计数,以及unique_ptr的不可复制性。此外,还讨论了两者在析构和release操作上的区别,以及可能出现的内存管理问题。
摘要由CSDN通过智能技术生成

在博文https://blog.csdn.net/qq_27717921/article/details/82940519已经介绍了unique_ptr和shared_ptr的使用,但是这两类的智能指针是如何做到管理指针的呢?

shared_ptr

头文件

template <typename T>
class SharedPointer {
public:
	SharedPointer(T *ptr = nullptr, const std::function<void(T*)> &del = Deleter()):
			p(ptr), use_c(new std::size_t(ptr != nullptr)), deleter(del) { }
	SharedPointer(const SharedPointer &);
	SharedPointer(SharedPointer &&) noexcept;
	SharedPointer& operator=(SharedPointer);
	~SharedPointer() { release(); }

	std::size_t use_count() { return *use_c; }

	bool unique() const { return *use_c == 1; }

	operator bool() const { return p != nullptr; }

	void reset(T* ptr = nullptr, const std::function<void(T*)> &del = Deleter());

	void swap(SharedPointer<T>&);

	T* get() const { return p; }

	T& operator*() const { return *p; }
	T* operator->() const { return p; }
private:
	std::size_t *use_c;
	T *p;
	std::function<void(T*)> deleter;

	void release();
};

1. 构造函数

shared_ptr<int> p1(new int (2));
SharedPointer(T *ptr = nullptr, const std::function<void(T*)> &del = Deleter()):
			p(ptr), use_c(new std::size_t(ptr != nullptr)), deleter(del) { }

涉及到的Deleter放在最后来讲。

采用new返回的指针初始化shared_ptr,调用构造函数,在堆上开辟一块存储空间,存放指向这块空间指针的数量,这块空间的地址初始化use_c. new int(2)返回的指针用于初始化p.

评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值