为啥 redis 使用跳表(skiplist)而不是使用 red-black?_陕西省延安市宜川县球码保温容器股份公司

+86 0000 88888

推荐产品

  • 为什么一般人不建议住别墅?
  • 为什么我觉得中国很谦虚,甚至有时候感觉中国对其他国家过分宽容,外国人却认为中国是列强呢?
  • 大家猜猜伊朗的结局如何?
  • 据报道称“浏览器内核有上千万行代码”,浏览器内核真的很复杂吗?

联系我们

邮箱:admin@admin.com
电话:+86 0000 88888
地址:广东省广州市番禺经济开发区 在线咨询

行业新闻

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

发布日期:2025-06-25 23:00:12 浏览次数:

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

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

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