C++智能指针unique_ptr的自定义删除器及其lambad表达式实现

问题引出:智能指针默认删除器做的事情太简单啦,仅仅调用delete释放资源可能还不够

unique_ptr类:

//第一个参数智能指针底层资源的类型,第二个参数是删除器,就是下面struct default_delete
//在删除资源时会调用删除器的operator()运算符重载,默认调用的是delete ptr.
template<class _Ty,class _Dx>	// = default_delete<_Ty>
class unique_ptr{ //... 

private:
	pointer _Myptr;	// the managed pointer,我们交给智能指针管理的资源的指针
	_Dx _Mydel;		// the deleter,删除器,定义如下
};

~unique_ptr() _NOEXCEPT
{
	_Mydel(_Myptr);
	//_Mydel是默认删除器,实现在下面,删除资源时,调用对象的operator()
}

删除器deleter:

//智能指针的删除器:
template<class _Ty>
struct default_delete{
//......
	
//default deleter for unique_ptr,其中_Ptr是智能指针底层资源的指针
void operator()(_Ty *_Ptr) const _NOEXCEPT
	{	// delete a pointer
		delete _Ptr; 
		//默认删除器仅仅只做一件事,只调用delete进行资源的释放
	}
	
//......
};

举一个实例,再说明这个问题:

int main(){
	std::unique_ptr<int> ptr(new int[100]);//delete []ptr
	return 0;
}
//对于一个数组的删除释放应该是delete []p,如果使用智能指针默认的删除器
//只会调用delete ptr,资源释放不彻底

改进,争对这种特殊的情况,添加自定义的一个删除器保证资源释放完全:

template<typename Ty>
class Deleter{
public:
	void operator()(Ty *ptr)const{
		cout<<"Call a custom method !!!!! "<<endl;
		delete []ptr;
	}
};
int main(){
	std::unique_ptr<int,Deleter<int>> ptr(new int[100]);//delete []ptr
	return 0;
}

执行结果:

Call a custom method !!!!! 

文件资源的自定义删除器:

template<typename Ty>
class Deleter{
public:
	void operator()(Ty *ptr)const{
		cout<<"Call a custom method !!!!! "<<endl;
		fclose(ptr);
	}
};
int main(){
	std::unique_ptr<FILE,Deleter<FILE>> ptr(fopen("data.txt","w"));
	return 0;
}

加入lambda表达式和function,避免多个删除器类的定义,否则每自定义一个删除器,都要去写一个对应的类,效率太低

#include <functional>

int main(){
	std::unique_ptr<int,function<void(int*)>> ptr1(new int[100],
		[](int*p)->void{
			cout<<"call my lambda deleter:int[]"<<endl;
			delete []p;
		}
	);
	std::unique_ptr<FILE,function<void(FILE*)>> ptr2(fopen("data.txt","w"),
		[](FILE*p)->void{
			cout<<"call my lambda deleter:FILE"<<endl;
			fclose(p);
		}
	);
	return 0;
}
  • 2
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
unique_ptrC++11引入的智能指针类,定义在<memory>头文件中。它可以通过指定对象类型作为模板参数来创建。例如,unique_ptr<int>是指向int类型对象的指针unique_ptr<double>是指向double类型对象的指针。\[1\] unique_ptr具有独占对象所有权的特点,即同一时间只能有一个unique_ptr指向一个对象,不能进行复制操作,只能进行移动操作。这意味着两个unique_ptr不能指向同一个对象。\[2\] unique_ptr还可以使用自定义删除deleter),通过lambda表达式或函数指针来指定删除对象的方式。例如,在创建unique_ptr时可以指定一个lambda表达式作为删除,用于在unique_ptr销毁时释放对象。\[3\] 总结来说,unique_ptrC++中一种独占所有权的智能指针,它提供了自动释放对象的功能,并且可以通过指定对象类型和自定义删除来灵活地管理资源。 #### 引用[.reference_title] - *1* [C++ 智能指针unique_ptr](https://blog.csdn.net/weixin_42322256/article/details/124058138)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [智能指针 unique_ptr 详解](https://blog.csdn.net/fuhanghang/article/details/113928128)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值