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

Views :
Update time : 2025-06-25 23:00:12

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

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

为啥 redis 使用跳表(skiplist)而不是使用 red-black?
Related News
Read More >>
Blog Post With Youtube Video 江西一救护车转运重症患儿 800 公里收 28000 元遭质疑,争议点是什么?哪些信息值得关注?
2025-06-19 20:40:11
江西一救护车转运重症患儿 800 公里收 28000 元遭质疑,争议点是什么?哪些信息值得关注?...
Blog Post With Youtube Video 2025 年高考,为啥大家反应冷淡得出奇?
2025-06-19 21:15:11
2025 年高考,为啥大家反应冷淡得出奇?...
Blog Post With Youtube Video 为什么中国足协成了“过街老鼠”了?
2025-06-19 20:20:10
为什么中国足协成了“过街老鼠”了?...
Blog Post With Youtube Video Rust连续多年成为最受欢迎的语言,为啥国内使用的人还是很少?
2025-06-19 20:30:10
Rust连续多年成为最受欢迎的语言,为啥国内使用的人还是很少?...

Leave Your Message