Serializable unordered set
Serializable unordered set 可序列化哈希set
#include <boost/algorithm/string/predicate.hpp>
#include <boost/exception/diagnostic_information.hpp>
#include <boost/exception_ptr.hpp>
#include <boost/archive/text_oarchive.hpp>
#include <boost/archive/text_iarchive.hpp>
#include <boost/config.hpp>
#include <boost/unordered_set.hpp>
#include <boost/shared_ptr.hpp>
#include <boost/serialization/string.hpp>
#include <boost/serialization/version.hpp>
#include <boost/serialization/split_member.hpp>
#include <boost/serialization/collections_save_imp.hpp>
#include <boost/serialization/collections_load_imp.hpp>
#include <boost/serialization/utility.hpp>
#include <boost/serialization/split_free.hpp>
#include <boost/thread/shared_mutex.hpp>
#include <boost/thread/locks.hpp>
namespace boost {
namespace serialization {
template<class Archive, typename TArgs >
inline void save(Archive & ar, boost::unordered_set<TArgs> const&t, unsigned) {
boost::serialization::stl::save_collection<Archive, boost::unordered_set<TArgs> >(ar, t);
};
template<class Archive, typename TArgs >
inline void load(Archive & ar, boost::unordered_set<TArgs> &t, unsigned) {
boost::serialization::stl::load_collection<Archive,
boost::unordered_set<TArgs>,
boost::serialization::stl::archive_input_set<Archive, boost::unordered_set<TArgs> >,
boost::serialization::stl::no_reserve_imp<boost::unordered_set<TArgs> >
>(ar, t);
};
// split non-intrusive serialization function member into separate
// non intrusive save/load member functions
template <class Archive, typename TArgs>
inline void serialize(Archive & ar, boost::unordered_set<TArgs> &t, unsigned file_version) {
boost::serialization::split_free(ar, t, file_version);
};
}
};
template<typename DataType>
class Serializable_unordered_set : boost::noncopyable
{
friend class boost::serialization::access;
// When the class Archive corresponds to an output archive, the
// & operator is defined similar to <<. Likewise, when the class Archive
// is a type of input archive the & operator is defined similar to >>.
template<class Archive>
void serialize(Archive & ar, const unsigned int version) {
ar & m_unordered_set;
}
private:
boost::unordered_set<DataType > m_unordered_set;
mutable boost::shared_mutex m_mtx_protect;
public:
Serializable_unordered_set()
{
}
void SetMap(boost::unordered_set<DataType>& newset)
{
m_unordered_set = newset;
}
void insert(DataType t) {
boost::unique_lock< boost::shared_mutex > lock(m_mtx_protect);
m_unordered_set.insert(t);
}
bool exist(DataType ky)
{
boost::shared_lock< boost::shared_mutex > lock(m_mtx_protect);
if (m_unordered_set.find(ky) != m_unordered_set.end())
return true;
return false;
}
void serialize_to(string file_path) {
boost::shared_lock< boost::shared_mutex > lock(m_mtx_protect);
std::ofstream fout(file_path.c_str());
boost::archive::text_oarchive oa(fout);
oa << m_unordered_set;
fout.close();
}
void deserialize_from(std::string file_path) {
boost::unique_lock< boost::shared_mutex > lock(m_mtx_protect);
std::ifstream file_in(file_path.c_str());
boost::archive::text_iarchive ia(file_in);
ia >> m_unordered_set; //recover from file
file_in.close();
}
};
typedef std::shared_ptr<Serializable_unordered_set<int>> hashset_int_SPtr;
Serializable unordered set的更多相关文章
- 对 Serializable和Parcelable理解
1.首先他们两个接口都是为了实现对象的序列化,使之可以传递,所谓序列化就是将对象信息装换成可以存储的介质的过程. 2.Serializable是jdk所提供的序列化接口,该接口存在于io包下,可想用于 ...
- java.io.Serializable 序列化接口
什么是序列化.反序列化? Serialization(序列化)是一种将对象以一连串的字节描述的过程: 反序列化deserialization是一种将这些字节重建成一个对象的过程. 序列化通俗一点说就是 ...
- serialVersionUID, ObjectInputStream与ObjectOutputStream类,Serializable接口,serialVersionUID的作用和用法
ObjectInputStream与ObjectOutputStream类所读写的对象必须实现Serializable接口,对象中的transient和static类型成员变量不会被读取和写入 Ser ...
- Bitset<>用于unordered container时的默认hash函数
自从c++11起,bitset用于unordered container,将会提供默认的hash函数. 在gcc中,相关代码如下: // DR 1182. /// std::hash speciali ...
- Java Serializable系列化与反系列化
[引言] 将 Java 对象序列化为二进制文件的 Java 序列化技术是 Java 系列技术中一个较为重要的技术点,在大部分情况下,开发人员只需要了解被序列化的类需要实现 Serializable 接 ...
- 在Activity之间传递参数(三)——serializable和parcelable的区别
传递值对象: 一.serializable实现:简单易用 serializable的迷人之处在于你只需要对某个类以及它的属性实现Serializable 接口即可.Serializable 接口是一种 ...
- Java中的Serializable接口transient关键字,及字节、字符、对象IO
1.什么是序列化和反序列化Serialization是一种将对象转为为字节流的过程:deserialization是将字节流恢复为对象的过程. 2.什么情况下需要序列化a)当你想把的内存中的对象保存到 ...
- Hibernate的实体类为什么要实现Serializable序列化接口?
Hibernate的实体类中为什么要继承Serializable? hibernate有二级缓存,缓存会将对象写进硬盘,就必须序列化,以及兼容对象在网络中的传输 等等. java中常见的几个类(如 ...
- Java 序列化Serializable详解
Java 序列化Serializable详解(附详细例子) Java 序列化Serializable详解(附详细例子) 1.什么是序列化和反序列化Serialization(序列化)是一种将对象以一连 ...
随机推荐
- 使用CSS3动画模拟实现小球自由落体效果
使用纯CSS代码模拟实现小球自由落体效果: html代码如下: <div id="ballDiv"> <div id="ball">&l ...
- java.io.IOException: Cannot run program "jad"
今天调试google tag manager, 需要看看google analytics source code,无奈没有源码,装个一个插件ejad 还是不行: java.io.IOException ...
- MySQL 通过semi join 优化子查询
半连接是MySQL 5.6.5引入的,多在子查询exists中使用,对外部row source的每个键值,查找到内部row source匹配的第一个键值后就返回,如果找到就不用再查找内部row sou ...
- 总结-css编码规范
一.注释 统一采用 :/* 注释内容 */ 二.命名 1.常用命名(多查单词) 参考命名规范.doc 2.选择器 1> [建议] 选择器的嵌套层级应不大于 3 级,位置靠后的限定条件应尽可能精确 ...
- javascript中的克隆
一:节点克隆 var p = document.getElementsByTagName("p")[0]; var cP = p.cloneNode();//克隆p节点 var c ...
- unix basic command
1. get start Command Example Description ls ls ls -a ls -l 输出目录文件 输出文件包括隐藏文件 输出文件详细信息 pwd pwd show p ...
- 服务器sh脚本自动登录(mac)
一不小心自己也有三台虚拟机了,每次都ssh -username@ip 然后在输入密码着实蛋疼,第一反应时脚本登录,但是作为脚本是逐行执行命令,是无法做到等待一个密码提示出现在输入密码的.查到mac下可 ...
- Django和Flask对于URL尾斜杠(back slash)的处理
最近在看Flask,其中提到了对于URL尾斜杠的处理.感觉算是一个需要注意的地方吧,就和Django的处理方式来进行一个简单的对比. 首先说下什么是尾斜杠. http://www.baidu.com/ ...
- 关于android的UI更新机制与误区
Android系统的消息队列和消息循环都是主线程的,其它后台服务等无法直接更新,必须通过下面的消息队列,由主线程的消息循环去依次执行更新ui: 同时对于费时间超过5秒的事件,比如网络链接等,建议新开线 ...
- Meta标签中的viewport属性及含义
一.什么是Viewport 手机浏览器是把页面放在一个虚拟的"窗口"(viewport)中,通常这个虚拟的"窗口"(viewport)比屏幕宽,这样就不用把每个 ...