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


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

更新时间:2025-06-28 15:15:12

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

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

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

案例推荐

case recommendation
  • 目前国内网盘,最尊重用户的是哪家?

    查看案例

  • 你身边身材最好的女生是什么样?

    查看案例

  • 大部分语言都用尖括号<>表示泛型,为什么golang要标新立异用中括号?

    查看案例

  • 央企的信创,是否有必要把 spring 替换成国产的 solon ?

    查看案例

  • 体制内女老师,被关系户欺负,大吼——"不干就给老子滚",我该怎么办?

    查看案例

  • FastApi性能是否真的接近Go?

    查看案例

  • 如何评价《一人之下》***第 721(764)话?

    查看案例

  • 姐妹们穿裙子露出安全裤打底裤会害羞吗?

    查看案例