我有一个boost :: multi_index_container与原始指针(是的,不是最好的主意,但遗憾的是我无法改变它...)和我需要删除所有释放内存的元素...如何擦除提升中的所有元素:multi_index应用“删除器”
有没有什么办法在boost :: multi_index_container中配置一个删除函数并调用某种清除方法?
在此先感谢。
我有一个boost :: multi_index_container与原始指针(是的,不是最好的主意,但遗憾的是我无法改变它...)和我需要删除所有释放内存的元素...如何擦除提升中的所有元素:multi_index应用“删除器”
有没有什么办法在boost :: multi_index_container中配置一个删除函数并调用某种清除方法?
在此先感谢。
是的。这个想法是使用一个RAII容器,就像一个智能指针。
通过这种方式,您可以确保删除程序在物品被删除时运行。
#include <boost/multi_index_container.hpp>
#include <boost/multi_index/member.hpp>
#include <boost/multi_index/mem_fun.hpp>
#include <boost/multi_index/hashed_index.hpp>
#include <boost/shared_ptr.hpp>
#include <boost/make_shared.hpp>
#include <iostream>
using namespace boost::multi_index;
struct Demo {
Demo(int id) : id(id) {}
int get_id() const { return id; }
~Demo() { std::cout << "some kind of deleter runs :)\n"; }
private:
int id;
};
typedef multi_index_container<boost::shared_ptr<Demo>,
indexed_by<
hashed_unique<const_mem_fun<Demo, int, &Demo::get_id>>>
> HostContainer;
int main()
{
{
HostContainer testHosts;
testHosts.insert(boost::make_shared<Demo>(42));
}
std::cout << "done\n";
}
打印
some kind of deleter runs :)
done
在阐述@ Sehe的答案,你可以有一个隐含接受裸指针,以便用户代码不需要改变一个智能指针:
#include <boost/multi_index_container.hpp>
#include <boost/multi_index/member.hpp>
#include <boost/multi_index/mem_fun.hpp>
#include <boost/multi_index/hashed_index.hpp>
#include <boost/shared_ptr.hpp>
#include <boost/make_shared.hpp>
#include <iostream>
using namespace boost::multi_index;
template<typename T>
struct implicit_shared_ptr:boost::shared_ptr<T>
{
implicit_shared_ptr(T* p):boost::shared_ptr<T>(p){}
};
struct Demo {
Demo(int id) : id(id) {}
int get_id() const { return id; }
~Demo() { std::cout << "some kind of deleter runs :)\n"; }
private:
int id;
};
typedef multi_index_container<
implicit_shared_ptr<Demo>,
indexed_by<
hashed_unique<const_mem_fun<Demo, int, &Demo::get_id>>>
> HostContainer;
int main()
{
{
HostContainer testHosts;
testHosts.insert(new Demo{42});
}
std::cout << "done\n";
}
谢谢您的回答......问题是,必须使用原始指针...这是一个古老的代码,我不能改变...... – thamurath 2015-03-02 11:27:39
那么答案是否定的。 (它怎么可能是旧代码,并且问题仍然是新的?) – sehe 2015-03-02 11:28:19
因为原始指针在代码中的许多点上都被使用......这些指针存储在一个集合类容器中,但现在我需要通过另一个键来搜索...所以我试图替换容器... – thamurath 2015-03-02 11:32:57