如何看待 Rust 写的 PNG 解码器比 C 实现更快?
golang 与rust 在服务器程序领域相比较,各有什么优劣势?
游泳给你带来哪些改变?
***拍大尺度片子时摄影师不会看光吗?
前端 css 中的 Grid 属性有哪些?
Node.js 性能为什么这么差?

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

发布日期:2025-06-28 15:15:12 浏览次数:0

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

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

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