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

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

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


MacOS的流畅,像是你在五星级酒店洗了个澡,毛巾有熏香、镜...
不会,龟龟的感情没有那么丰富,它们不知道孤独是什么,它们只知...
你大扔子,你就搜胸围120 你大翘尻,你就搜臀围140 我不...
如果你用光纤,某天网断了之后,就会掏出手机检测,然后看到一个...
这种内存分装包装大概率(目前统计概率在60%~70%)是**...
目前来看不会比24日的更高,但是也是超保水位的大洪水。 ...
现在pr安装包其实非常好找了,不像以前,某度搜索下载下来的,...
node_modules 的问题(尤其是大小问题),主要其实...
我把7年前的Thinkpad X1 安装Ubuntu 24用...
自研新作 flutter3.32+dart3.8+deeps...
