首页 > 基础资料 博客日记
leveldb-impl:SnapshotImpl.java
2023-07-24 20:41:34基础资料围观489次
Java资料网推荐leveldb-impl:SnapshotImpl.java这篇文章给大家,欢迎收藏Java资料网享受知识的乐趣
实现leveldb-api的snapshot接口:
public class SnapshotImpl implements Snapshot
在leveldb快照中每次都是用一个序列号保存当前插入的这一条记录,因此当插入多条相同的记录时,通过序列号来确定那一条是最新的记录,在leveldb的快照中,在调用一个快照时,只要获取在当前快照序列号以下的记录,就可以读取到这个快照之前的数据。
private final AtomicBoolean closed = new AtomicBoolean(); private final Version version; private final long lastSequence;
SnapshotImpl(Version version, long lastSequence) { this.version = version; this.lastSequence = lastSequence; this.version.retain();
}
获取version和lastSequence
public long getLastSequence() { return lastSequence; } public Version getVersion() { return version; }
把lastSequence转化为String
@Override public String toString() { return Long.toString(lastSequence); }
判断snapshot和version是否一致:
public boolean equals(Object o) { if (this == o) { return true; } if (o == null || getClass() != o.getClass()) { return false; } SnapshotImpl snapshot = (SnapshotImpl) o; if (lastSequence != snapshot.lastSequence) { return false; } if (!version.equals(snapshot.version)) { return false; } return true; }
转换impl为hash编码:
@Override public int hashCode() { int result = version.hashCode(); result = 31 * result + (int) (lastSequence ^ (lastSequence >>> 32)); return result; } }
ReadOption中保持了snapshot,在拿到快照后,取出快照中的sequence number,根据传入的key和sequence number进文件中查找记录,这样就能查找快照之前的数据。
文章来源:https://www.cnblogs.com/yunqihao/p/16497394.html
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:jacktools123@163.com进行投诉反馈,一经查实,立即删除!
标签:
相关文章
最新发布
- SpringBoot--如何整体读取多个配置属性及其相关操作
- 个人网站一键引入免费开关评论功能 giscus
- Java开发笔记(一百五十五)生成随机数的几种途径
- 榨干 Claude Code 的 16 个实用小技巧(高端玩法,建议收藏!)
- NBA巨星詹姆斯表变老嫂子了?这锅Viggle Ai得背/Ai视频创作/Ai魔性视频创作/Ai优质视频创作
- Java简历、面试、试用期、转正
- 使用Apollo配置中心,**静态字段通过`@Value`的setter方法可以实现热更新**
- vivo Pulsar 万亿级消息处理实践(3)-KoP指标异常修复
- MybatisPlus使用详情
- G1收集器:JVM垃圾回收的新一代王者