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


为啥 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
  • MacOS的哪个设计让你非常恼火?

    查看案例

  • 小区楼下的自动售水机的水干净吗?

    查看案例

  • 是不是 Mac Mini(M4) 不值得?

    查看案例

  • 华为自研的仓颉编程语言将于 7 月 30 日开源,这款语言将如何影响未来的开发趋势?

    查看案例

  • 为什么在中国,一间「看起来没什么用」的房间最终都会被装修成书房?

    查看案例

  • 为什么师父不愿把真本事传给弟子?

    查看案例

  • 为什么明明35岁以上的员工更稳定,招聘时不要,被裁的也是他们?

    查看案例

  • 为什么利用无线电***很快就会被警察抓到?

    查看案例