为啥 redis 使用跳表(skiplist)而不是使用 red-black?_河南省洛阳市洛宁县在酒洗护用品有限公司

某某工程技术有限公司重点推荐单位25年专注国家重点新产品—蜂窝式电捕焦油器的研发、生产

全国咨询热线

当前位置:当前位置: 首页 >

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

文章出处:网络 人气:发表时间:2025-06-28 09:55:16

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

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

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