c++ hash_map 持久化

c++ 中怎么将hash_map 存储到文件中 这个牵扯到序列化和反序列化 有做过这方面的大神吗?据说boost 库提供了一个 方法 但是查到的资料很少。有谁有这方面的资料 共享下 谢谢!!!

阅读 7.6k
3 个回答

只要能遍历 hash_map,就可以序列化,而一般集合类数据结构都是可以遍历的,hash_map 也不例外

序列化

通过 hash_map 对象的 size() 方法取得项数,写入流,
通过 hash_map::iterator 遍历 hash_map 对象,依次将 key 和 value 写入流。

反序列化

读取的时候产生一个 hash_map 对象,
先读取数量,然后按这个数量进行一个 for 循环,
依次读入 key 和 value 对,并插入到刚才的 hash_map 对象中

如果考虑第三方的库,推荐google的protobuf,可直接将hash_map对象序列化后存储;

不知道你的数据规模还有hash_map的修改频次啊,我就说说我现在的情况和实现吧
我的map大概几千到几万项,增删改都不频繁,持久化做到共享内存里。
所以共享内存的结构就定义了一个struct,里面就是key和value。程序运行时对map的增删改全部转化为对共享内存的写,程序重启的时候从共享内存里读出所有的项,重新形成map。

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题