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

Views :
Update time : 2025-06-28 15:15: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 如何看待演员夏雨称「真正玩极限运动的都是胆小的人」,如何理解这一观点?
2025-06-28 19:10:11
如何看待演员夏雨称「真正玩极限运动的都是胆小的人」,如何理解这一观点?...
Blog Post With Youtube Video 南昌真的没吸血吗?
2025-06-28 19:10:11
南昌真的没吸血吗?...
Blog Post With Youtube Video 在农村建房子的后悔了吗?
2025-06-28 19:15:11
在农村建房子的后悔了吗?...
Blog Post With Youtube Video 迷茫。J***a还是.net?
2025-06-28 19:05:11
迷茫。J***a还是.net?...

Leave Your Message