重载全局new/delete具体实现内存检测

本文详细阐述了智能指针的实现过程,并提出了改进方案。通过代码实例,展示了如何利用智能指针来管理资源,减少内存泄漏风险。重点讨论了智能指针的复制构造函数、赋值操作符、析构函数以及使用计数器来跟踪对象引用计数的机制。

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

按照上面转载的文章的思路,只是小小的实现了一下。还有很多不足,等到有想法的时候再修改。
#include <iostream>
#include <stdlib.h>
using namespace std;
template <typename T>
class smartPtr
{
public:
	smartPtr(T *ptr):_ptr(ptr),useCountPtr(new int(1)){
     

	}
	smartPtr(const smartPtr<T> & org):_ptr(org.getPtr()),useCountPtr(org.getUseCountPtr()){
    ++(*useCountPtr);
	}
	smartPtr<T> & operator=(const smartPtr& org){
		
			/* code */
			_ptr=org.getPtr();
			useCountPtr=org.getUseCountPtr();
			++(*useCountPtr);			
		
		
     
      return *this;

	}
	smartPtr<T>* operator=(const smartPtr<T> *org){
		/* code */
			_ptr=org->getPtr();
			useCountPtr=org->getUseCountPtr();
			++(*useCountPtr);			

     
           return this;

	}
	void setValue(T date){
      *_ptr=date;
	}
	T getValue() const{
    return *_ptr;
	}
	T *getPtr() const{

    return _ptr;

	}
	int *getUseCountPtr() const {

return useCountPtr;

	}
	~smartPtr(){
		cout<<"distructor usecount is "<<(*useCountPtr)-1<<endl;
		if (--(*useCountPtr)==0)
		{
			/* code */delete _ptr;
			_ptr=NULL;
			cout<<"ptr delete safely!!!";
		}
	}
private:
	T* _ptr;
	int *useCountPtr;
	/* data */
};




int main(){
   int* num=new int(10);
   smartPtr<int> *pp=new smartPtr<int>(num);
   smartPtr<int> *pp1=new smartPtr<int>(*pp);
   smartPtr<int> ss=*pp;
   smartPtr<int> *pp2=pp;
   cout<<pp->getValue()<<endl;
   delete pp;
   delete pp1;
   delete pp2;

}

输出结果:

this cpp has memory leak!!!!
D:\code\go1\mesh.cpp line :96 new ptr not delete!!!
will delete later...
D:\code\go1\mesh.cpp line :96  deleted.
D:\code\go1\mesh.cpp line :98 new ptr not delete!!!
will delete later...
D:\code\go1\mesh.cpp line :98  deleted.

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值