为啥 redis 使用跳表(skiplist)而不是使用 red-black?_沁源网站建设_网站建设公司_网站建设设计制作_seo优化
新鲜 / 健康 / 便利 / 快速 / 放心
看到有人拿LevelDB/RocksDB和Redis的跳表来比较我是不太同意的,leveldb和rocksdb的跳表首先他们底层是LSM,跳表的目的本身是为了做memtable用,而跳表能提供很好的concurrency(lockfree简单),而红黑树写个lockfree可能写死还没有跳表性能强,所以用跳表是很情有可原的。
而redis这个最开始只有单线程的用跳表我个人还是认为是历史遗留问题(偷懒)。
上一篇 : Web后端开发,用Python还是Go呢?
下一篇 : 你卡过最厉害的bug是什么?