你现在的位置是:当前位置: 首页 >


为啥 redis 使用跳表(skiplist)而不是使用 red-black?

更新时间:2025-06-26 02:55:10

看到有人拿LevelDB/RocksDB和Redis的跳表来比较我是不太同意的,leveldb和rocksdb的跳表首先他们底层是LSM,跳表的目的本身是为了做memtable用,而跳表能提供很好的concurrency(lockfree简单),而红黑树写个lockfree可能写死还没有跳表性能强,所以用跳表是很情有可原的。

而redis这个最开始只有单线程的用跳表我个人还是认为是历史遗留问题(偷懒)。

为啥 redis 使用跳表(skiplist)而不是使用 red-black?

案例推荐

case recommendation
  • C/C++中如何稳定地每隔5ms执行某个函数?

    查看案例

  • 你的低成本爱好是什么?

    查看案例

  • 周芷若一个船夫的女儿,容貌真的比得上皇家女子吗?

    查看案例

  • vue + tsx 的开发体验能追得上 react+tsx么?

    查看案例

  • OpenAI 推出 o3-pro 推理模型,实际体验如何?

    查看案例

  • 什么是微软式中文?

    查看案例

  • 到底是9800x3d+5070ti还是u7+5080?

    查看案例

  • 为什么现在糖尿病越来越多?

    查看案例