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

Views :
Update time : 2025-06-26 02:55:10

看到有人拿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-27 17:10:13
柳州的债务,谁来还?用什么还?怎么还?...
Blog Post With Youtube Video 可不可以发一张你觉得最有感觉的照片?
2025-06-27 15:50:13
可不可以发一张你觉得最有感觉的照片?...
Blog Post With Youtube Video 为什么Rust的包管理器Cargo这么好用?
2025-06-27 17:05:13
为什么Rust的包管理器Cargo这么好用?...
Blog Post With Youtube Video M4 Mac mini2024款,这种主机到底怎么样呀?
2025-06-27 16:15:14
M4 Mac mini2024款,这种主机到底怎么样呀?...

Leave Your Message