C++11补充:智能指针如std::unique_ptr如何添加自定义的deleter

关于智能指针的问题,有时候为了方便,需要在析构时附加一些清理操作,或者,有的指针本身来自C的库文件中,这时候,就非常期望能够使用自定义的deleter,

但是标准C++创建函数如std::make_unique / std::make_shared 等不支持创建带有自定义deleter的智能指针,这时,我们只能使用自己的办法,

cpp 复制代码
#include <memory>
#include <iostream>

class myclass {
public:
	myclass() {
		std::cout << "myclass" << std::endl;
	}

	~myclass() {
		std::cout << "~myclass" << std::endl;
	}

	void doSomething() {
		std::cout << "myclass is doing something" << std::endl;
	}
};

class A {
public:
	A(){
		std::cout << "A" << std::endl;
	}

	~A(){
		std::cout << "~A" << std::endl;
	}

	void doSomething() {
		std::cout << "A is doing something" << std::endl;
	}
};

struct my_creator_s {
	myclass* p = new myclass();
	A* a = new A();
};
struct my_deleter_s {
	void operator()(myclass* p) { delete p; }

};
struct my_deleter_s2 {
	void operator()(my_creator_s* s) { delete s->p; delete s->a; }
};

myclass* mycreator() {
	return new myclass();
}
void mydeleter(myclass* p){
	delete p;
};

int Test1() {
	std::cout << "----------------------------Test Method 1-----------------------------" << std::endl;
	myclass* myptr = new myclass;
	std::unique_ptr<myclass, decltype(&mydeleter)> ptr{ myptr,  &mydeleter };
	ptr->doSomething();
	return 0;
}

int Test2() {
	std::cout << "----------------------------Test Method 2-----------------------------" << std::endl;
	std::unique_ptr<myclass, my_deleter_s> ptr2 = std::unique_ptr<myclass, my_deleter_s>(new myclass(), my_deleter_s());
	ptr2.get()->doSomething();
	return 0;
}

int Test3() {
	std::cout << "----------------------------Test Method 3-----------------------------" << std::endl;
	std::unique_ptr<my_creator_s, my_deleter_s2> ptr3 = std::unique_ptr<my_creator_s, my_deleter_s2>(new my_creator_s(), my_deleter_s2());
	ptr3.get()->a->doSomething();
	return 0;
}

int main() {
	Test1();
	Test2();
	Test3();
	return 0;
}

这段代码的输出如下,

----------------------------Test Method 1-----------------------------

myclass

myclass is doing something

~myclass

----------------------------Test Method 2-----------------------------

myclass

myclass is doing something

~myclass

----------------------------Test Method 3-----------------------------

myclass

A

A is doing something

~myclass

~A

说明:这里写了两个creator,函数mycreator没有用到;deleter一个采用了struct的办法,一个是采用了void函数的办法,大家可以自己尝试; 对于需要同时处理多个参数或变量的形式,建议采用struct或class的形式,Test Method3展示了如何使用creator或者说constructor创建的办法,写成这种方式是因为智能指针的deleter中只接受一个参数,例如,不能写成这样的,

cpp 复制代码
struct my_deleter_s2 {
	void operator()(myclass* p, A* a) { delete p; delete a; }
};

参考附录:

Custom Deleter for C++ Smart Pointers - Lei Mao's Log Book

本文结束

相关推荐
IT WorryFree2 分钟前
Zabbix 7.4 API 可同步全量参数清单(同步第三方系统专用)
java·开发语言·zabbix
码云骑士13 分钟前
06-Python装饰器从入门到源码(上)-闭包与自由变量
开发语言·python
码云骑士21 分钟前
10-Python运行时内存模型-栈帧-堆-引用计数-GC分代回收的全景图
开发语言·python
智码看视界28 分钟前
老梁聊全栈系列 JavaScript语言本质:从原型链到异步编程的深度解析
开发语言·javascript·全栈·javascript核心
AI科技星31 分钟前
数术工坊・八卷全书【本源创世终极版・万世定稿】
开发语言·网络·量子计算·拓扑学
雾沉川33 分钟前
Visual C++ 运行库合集 v105.0 部署与故障排查技术指南
开发语言·c++·dll
码云骑士34 分钟前
02-Python可变对象与不可变对象(上)-赋值陷阱与函数传参的暗坑
开发语言·python
gaohe26AIliuzeyu43 分钟前
Java内部类
java·开发语言
AI科技星1 小时前
数术工坊・八卷全书(番外・实战升华副卷)【终极典藏定稿|完整无删减】
c语言·开发语言·网络·量子计算·agi
丘山望岳1 小时前
剑起霜华——平衡二叉树(AVL树 )精讲
开发语言·数据结构·c++