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


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

更新时间:2025-06-25 17:35:18

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

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

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

案例推荐

case recommendation
  • 如何看待rust编写的zed编辑器?

    查看案例

  • MySQL不香吗,为啥还要Elasticsearch?

    查看案例

  • 前端,后端,全栈哪个好找工作?

    查看案例

  • J***aScript 这种语言特性十分糟糕的语言流行起来是不是一场灾难?

    查看案例

  • 为什么福建没有像江苏一样散装?

    查看案例

  • 如何评价 Bilibili 未经用户同意私自开启大量 UPnP 端口,疑似盗用用户的带宽?

    查看案例

  • jwt的设计合理吗?

    查看案例

  • 有哪些是你用上了mac才知道的事?

    查看案例