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

Views :
Update time : 2025-06-28 09:55:16

看到有人拿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-25 13:10:17
社保断缴的后果有些什么?...
Blog Post With Youtube Video 印度是真的烂还是咱们在信息茧房里面?
2025-06-25 13:40:17
印度是真的烂还是咱们在信息茧房里面?...
Blog Post With Youtube Video 为什么Go仅仅160MB的安装包就可以编译程序,而Rust却还需要几个GB的VC++才能编译?
2025-06-25 13:10:17
为什么Go仅仅160MB的安装包就可以编译程序,而Rust却还需要几个GB的VC++才能编译?...
Blog Post With Youtube Video cloudflare的1.1.1.1和warp有什么区别?
2025-06-25 12:30:19
cloudflare的1.1.1.1和warp有什么区别?...

Leave Your Message