首页 > 基础资料 博客日记
leveldb-Impl : SequenceNumber.java
2023-07-26 17:37:19基础资料围观411次
这篇文章介绍了leveldb-Impl : SequenceNumber.java,分享给大家做个参考,收藏Java资料网收获更多编程知识
SequenceNumber.java:leveldb/SequenceNumber.java at master · dain/leveldb · GitHub
public final class SequenceNumber { // We leave eight bits empty at the bottom so a type and sequence# // can be packed together into 64-bits. public static final long MAX_SEQUENCE_NUMBER = ((0x1L << 56) - 1); private SequenceNumber() { } public static long packSequenceAndValueType(long sequence, ValueType valueType) { checkArgument(sequence <= MAX_SEQUENCE_NUMBER, "Sequence number is greater than MAX_SEQUENCE_NUMBER"); requireNonNull(valueType, "valueType is null"); return (sequence << 8) | valueType.getPersistentId(); } public static ValueType unpackValueType(long num) { return ValueType.getValueTypeByPersistentId((byte) num); } public static long unpackSequenceNumber(long num) { return num >>> 8; } }
sequenceNumber是一个64位的数。每次更新时,由SequenceNumber来标识,整个 db 有一个全局值保存着当前使用到的 SequnceNumber。SequnceNumber 在 leveldb 有重要的地位,key 的排序,compact 以及 snapshot 都依赖于它. SequnceNumber只占56bits,ValueType占用8bits
文章来源:https://www.cnblogs.com/yunqihao/p/16501077.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垃圾回收的新一代王者