C程序:复杂数据结构的快照问题
问题描述:由于想保存数据结构在任意时刻的快照(由用户来触发),需要对当前的数据状态进行深度复制,但是,该结构较为复杂,还没有找到有效的方法来实现。
数据结构代码:
struct value {
value* prev;
value* next;
int value;
};
struct entry {
entry* prev;
entry* next;
value* values;
char key[MAX_KEY_LENGTH];
};
struct snapshot {
snapshot* prev;
snapshot* next;
entry* entries;
int id;
};
如下图描述的那样,1、2、3分别是三个时刻的快照,其保存的是三个时刻的current database state;current database state是当前用户编辑数据的环境。现在的问题就是,如何将current database state复制一份并保存。同时,快照1、2、3还可以被rollback到current database state。
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(3)
一个方案是把数据存成c++里的
vector
, 然后serialize
, 比如用boost::serialization
.将数据以二进制的形式保存到日志文件中,需要的时候再从这个日志文件中读取出来,一般思路应该都是这个样子的。
我目前的方法是,使用malloc在内存中逐一为current state分配空间,然后按照其原有连接一一复原。代码如下: