为啥 redis 使用跳表(skiplist)而不是使用 red-black?_陕西省西安市阎良区夏仁气体放电灯有限责任公司

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

后台-模块-广告管理-内容头部广告位
后台-模块-广告管理-内容头部广告位

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

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

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

豫-ICP备12309699号-1|网站地图
本文地址:
豫-ICP备12309699号-1|网站地图本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
后台-模块-广告管理-内容底部广告位
后台-模块-广告管理-内容底部广告位