leveldb 查找过程

         我们先看下面代码

1074   {
1075     mutex_.Unlock();
1076     // First look in the memtable, then in the immutable memtable (if any).
1077     LookupKey lkey(key, snapshot);
1078     if (mem->Get(lkey, value, &s)) {
1079       // Done
1080     } else if (imm != NULL && imm->Get(lkey, value, &s)) {
1081       // Done
1082     } else {
1083       s = current->Get(options, lkey, value, &stats);
1084       have_stat_update = true;
1085     }
1086     mutex_.Lock();
1087   }


从上面的代码可以看出,查询过程首先是在memTable不查找,如果找不到并且存在 immutable memtable,那么就在这里查找, 实在找不到,最后去ssTable中查找。 
        我们知道memTable 和immutable memTable都是使用跳表的结构实现,他们的查找就是在跳表中查找,这里就不介绍,我们主要来介绍下ssTable查找过程。 

version_set.cc

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值