shared_ptr智能指针实现

实现说明

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;
}

测试结果

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/tsh123321/article/details/88966611