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

Views :
Update time : 2025-06-25 23:30:11

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

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

为啥 redis 使用跳表(skiplist)而不是使用 red-black?
Related News
Read More >>
Blog Post With Youtube Video 人为什么需要睡觉?人睡觉的时候身体都在做什么?
2025-06-20 01:40:10
人为什么需要睡觉?人睡觉的时候身体都在做什么?...
Blog Post With Youtube Video 网络小白如何建立一个网站,供别人下载文件(主要是PDF和MP3)?
2025-06-20 02:15:10
网络小白如何建立一个网站,供别人下载文件(主要是PDF和MP3)?...
Blog Post With Youtube Video 30岁的人生有多无力?
2025-06-20 01:50:09
30岁的人生有多无力?...
Blog Post With Youtube Video 有哪些开源web应用漏洞扫描工具?
2025-06-20 02:50:09
有哪些开源web应用漏洞扫描工具?...

Leave Your Message