两种创建类实例的方法

Person p1(10); 		        //对象创建在栈空间,值引用,系统自动析构

Person * p1 = new Person(10);	//对象创建在堆空间,指针访问,需要程序员delete调用析构
p1->showAge();
delete p1;

那么,有没有一种让对象分配在堆内存空间,使用指针的方式访问,但又不用程序员手动delete堆空间的实现呢???

 

智能指针

定义:用来托管自定义类型的对象,让对象进行自动的释放。

功能:既能让对象分配在堆内存空间,使用指针的方式访问,又不用程序员手动delete堆空间(系统实现)。

 

分析:设计一个smartPointer类,smartPointer类的指针成员来访问管理我所要管理的对象。这样管理的对象可以分配在堆空间(使用new创建),而smartPointer类的实例确是在栈上创建的,在smartPointer类的析构中实现管理对象的delete,这样就实现了系统自动delete对象了;进一步在smartPointer类重载 '*' '->'运算符,可以像指针一样访问我要管理的对象,为智能指针。

我的码云:https://gitee.com/hinzer/my-notes-of-C_plus/tree/master/step8/smartPointer

 

智能指针创建步骤

1.定义指针成员,用来管理目标对象;
2.构造函数中,初始化指针成员;
3.析构函数中delete处理目标对象;
4.分别实现'->' '*'运算符的重载;

 

代码实现

#include<iostream>
using namespace std;

class Person
{
public:
	Person(int age)
	{
		this->m_Age = age;
	}

	void showAge()
	{
		cout << "年龄为:" << this->m_Age << endl;
	}
	~Person()
	{
		cout << "Person的析构调用" << endl;
	}

	int m_Age;
};


class smartPointer
{
public:
	smartPointer(Person * person)
	{//2.person指针初始化
		this->person = person;
	}

	
	Person * operator->()
	{//3.重载->让智能指针对象 想Person *p一样去使用
		return this->person;
	}

	
	Person& operator*()
	{//3.重载 * 
		
		return *this->person;
	}

	~smartPointer()
	{//2.释放目标对象所在的堆空间
		cout << "智能指针析构了" << endl;
		if (this->person !=NULL)
		{
			delete this->person;
			this->person = NULL;
		}
	}

private:
	Person * person;	//1.创建指针成员(访问堆内存)
};

void test01()
{
	//Person p1(10); 					//对象创建在栈空间,系统自动析构

	//Person * p1 = new Person(10);		//对象创建在堆空间,需要程序员delete调用析构
	//p1->showAge();
	//delete p1;

	smartPointer sp(new Person(10)); //sp开辟到了栈上,自动释放

	//
	sp->showAge(); 		// sp->->showAge(); 编译器优化了 写法
	(*sp).showAge();
}


int main()
{
	test01();
}

 

编译运行