shared_ptr智能指针实现

本文详细介绍了如何实现shared_ptr智能指针,包括重载解引用和箭头运算符,自定义析构函数以确保资源正确释放,以及定义拷贝构造函数和拷贝赋值运算符以管理引用计数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

实现说明

1.要对解引用运算符和箭头运算符进行重载

类似:

 T& operator*();   //解引用重载
 T* operator->();  //箭头运算符重载

2.自定义析构函数

智能指针的成员变量有堆上分配出来的部分,默认的析构函数不能完全的释放资源

3.定义拷贝构造函数和拷贝赋值运算符重载

引用计数就是在上述函数中完成,所以需要自定义实现

实现代码

template <typename T>
class Shared_ptr
{
public:
	//构造函数
	Shared_ptr() : ptr_(nullptr), count_(new int(0))
	{
		cout<<"申请空间:"<<ptr<<endl;
	}

	Shared_ptr( T* ptr ) : ptr_(ptr), count_(new int(0))
	{
		cout<<"申请空间:"<<ptr<<endl;
		*count_ = 1;
	}

	//析构函数
	~Shared_ptr()
	{
		--(*count_);
		if(*count_ == 0)
		{
			cout<<"释放空间:"<<ptr_<<endl;
			delete ptr_;
			delete count_;
			ptr_ = nullptr;
			count_ = nullptr;
		}
	}

	//拷贝构造函数
	Shared_ptr( const Shared_ptr& ptr )
	{
		count_ = ptr.count_;
		ptr_ = ptr.ptr_;
		++(*count_);
	}

	//解引用运算符
	T& operator*()
	{
		return *ptr_;
	}

	//箭头运算符
	T* operator->()
	{
		return ptr_;
	}

	//重载布尔值操作
	operator bool()
	{
		return ptr_ == nullptr;
	}

	T* get()
	{
		return ptr_;
	}

	int use_count()
	{
		return *count_;
	}

	bool unique()
	{
		return *count_ == 1;
	}

	void swap( Shared_ptr& ptr )
	{
		std::swap(*this, ptr);
	}
private:
	int* count_;
	T* ptr_;
};

测试代码


int main()
{
	Shared_ptr<int> p1(new int);
	*p1 = 222;
	cout<<"值:"<<*p1<<" 引用计数:"<<p1.use_count()<<endl;
	{
		Shared_ptr<int> p2(p1);
		*p2 = 333;
		cout<<"值:"<<*p2<<" 引用计数:"<<p1.use_count()<<endl;

		Shared_ptr<int> p3(p2);
		*p3 = 444;
		cout<<"值:"<<*p3<<" 引用计数:"<<p1.use_count()<<endl;
	}

	cout<<"引用计数:"<<p1.use_count()<<endl;

	Shared_ptr<string> q1(new string("我是string1"));
	cout<<(*(q1)).c_str()<<endl;

	Shared_ptr<string> q2(new string("我是string2"));
	q2.swap(q1);
	cout<<(*(q1)).c_str()<<endl;

	system("pause");
	return 0;
}

测试结果

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值