自己实现一个C++ 智能指针

本文介绍了智能指针的基本概念,以及为何需要使用智能指针来避免内存泄漏。通过实例展示了如何从头开始实现一个简单的智能指针类`SuperPtr`,包括构造、析构函数以及重载`operator*`、`operator->`,使得智能指针能够像普通指针一样方便地使用。
摘要由CSDN通过智能技术生成

智能指针实际上的作用就是对程序员申请的内存进行自动释放。原理就是利用了类的析构函数的原理,类变量在生命周期结束的时候,会自动调用析构函数,执行析构函数的中的内容,一般用new的地方,都可以使用智能指针

啥是智能指针:
class A;
假如我们有个A类,那么如果在某处代码我们进行了一个操作:
A* a=new A;
我们知道,如果我们new出来一个A,那么我们必须在之后的某处手动释放掉这个A,
也就是说,我们要在a指向的对象已经无用之后,进行:
delete a;的操作.
C++的这个没有自动资源释放的设计吓跑了一堆初学者,坑苦了一堆程序员,
有时候因为忘记写一个delete,内存各种泄露,比如:
int main(void) {
A* a=new A;
Func(a); //此处干了一些事情
//哇!忘记释放了!
return 250;
}
可以看到,当main函数执行return之后,所有处于main中的临时变量都将被销毁,
那么指针a也要被销毁,既然唯一一个指向new A的指针都被销毁了,那么这个new出来的
A就永远都不可能再有机会被找到并销毁了.(这可不是obj-C!),那么,也就是说,
我找不到任何一个理由,让唯一一个指向new A的指针销毁时,被指向的对象不被释放! 

当然,你会说:"我牛逼,我脑细胞死得比你多,我从不忘了delete."
好,你厉害,我活着没那么累,我写了个模板:
template<typename obj>
class SuperPtr
{
public:
SuperPtr():ptr(nullptr){};
SuperPtr(obj* const newObject):ptr(newObject){}
~SuperPtr() { delete ptr; }
obj* ptr;
};
好了,我们的SuperPtr就是一个崭新的智能指针,当需要创建一个对象的时候,
我们:
int main(void) {
SuperPtr<A> a=new A;
Func(a.ptr); //此处干了一些事情
return 0;
}
可以看到,当main函数结束时,会自动调用a的析构函数,自动销毁a指向的对象.
不需要你写任何delete.
当然,你会说: a.ptr好丑! 太恶心了. 还是原始指针方便!
没关系,我们重载一下SuperPtr的操作符:
template<typename obj>
class SuperPtr
{
public:
SuperPtr():ptr(nullptr

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值