带有自定义删除器和分配器的 shared_ptr
Posted
技术标签:
【中文标题】带有自定义删除器和分配器的 shared_ptr【英文标题】:shared_ptr with custom deleter and allocator 【发布时间】:2013-08-25 00:54:23 【问题描述】:我正在用 c++ 编写,但我的 RAII 有一些问题。
我想使用指向结构的指针作为私有成员来构建自定义类。
struct mystruct;
typedef struct mystruct mystruct_t;
class container
public:
container();
private:
shared_ptr<mystruct_t> data;
mystruct* init();
void destroy(mystruct*);
;
在类的构造函数中,我想构造智能指针,传递给它分配器和析构器方法。这两种方法来自一个库(它们在分配内存后准备结构),我无法修改它们。所以我想将它们包装在两个类方法中(我称它们为 init 和 destroy)。
我以为 shared_ptr 的委托构造函数是这样的
container()
: data(nullptr, std::bind(&container::destroy), std::bind(&container::init) )
但它不起作用。 任何的想法?谢谢!
【问题讨论】:
C++ 中不需要typedef struct
s'
Euhm,实际上该结构来自我必须包装的 c 库。我试图将所有涉及的代码总结得更清楚。我已经知道了,但是谢谢! :)
【参考方案1】:
假设您的 destroy()
和 init()
方法不是static
成员,它们首先需要一个对象来处理,其次它们可能需要接受一些参数。也就是说,我希望 bind()
表达式看起来更像
data(nullptr,
std::bind(&container::destroy, some_container, _1),
std::bind(&container::init, some_container))
也就是说,我怀疑您是否会对分配器感到满意:您最好将 std::shared_ptr<mystruct>
最初设置为默认构造,并在您掌握它后分配构造的资源:
this->data = std::shared_ptr<mystruct>(container->init(),
std::bind(&container::destroy, container, _1));
std::shared_ptr<T>
的构造函数的第三个参数是分配器,它们比处理对象构造的东西更复杂。
【讨论】:
我想传递 init() 方法的结果而不是 nullptr,然后只传递删除器功能。但我喜欢优雅的东西,我想处理分配器:) 一些链接传递给我?我在网上找东西花了三个小时。 @user2714602:分配器做了很多事情,而您创建对象的接口不适合!虽然我可以想象你可以让分配器做正确的事情(在这种情况下它也会处理释放,顺便说一句)我不会沿着这条路线去寻找创建现成对象的东西。以上是关于带有自定义删除器和分配器的 shared_ptr的主要内容,如果未能解决你的问题,请参考以下文章
[cpp] 使用 shared_ptr的自定义删除函数模拟 go 语言的 defer 功能