leveldb-impl:SnapshotImpl.java
2022/7/21 1:24:53
本文主要是介绍leveldb-impl:SnapshotImpl.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进文件中查找记录,这样就能查找快照之前的数据。
参考:level Snapshot源码分析_叶长风的博客-CSDN博客
这篇关于leveldb-impl:SnapshotImpl.java的文章就介绍到这儿,希望我们推荐的文章对大家有所帮助,也希望大家多多支持为之网!
- 2024-11-23Springboot应用的多环境打包入门
- 2024-11-23Springboot应用的生产发布入门教程
- 2024-11-23Python编程入门指南
- 2024-11-23Java创业入门:从零开始的编程之旅
- 2024-11-23Java创业入门:新手必读的Java编程与创业指南
- 2024-11-23Java对接阿里云智能语音服务入门详解
- 2024-11-23Java对接阿里云智能语音服务入门教程
- 2024-11-23JAVA对接阿里云智能语音服务入门教程
- 2024-11-23Java副业入门:初学者的简单教程
- 2024-11-23JAVA副业入门:初学者的实战指南