Redis 解决键冲突


当有两个或以上数量的键被分配到了哈希表数组的同一个索引上面时, 我们称这些键发生了冲突(collision)。

Redis 的哈希表使用链地址法(separate chaining)来解决键冲突: 每个哈希表节点都有一个 next 指针, 多个哈希表节点可以用 next 指针构成一个单向链表, 被分配到同一个索引上的多个节点可以用这个单向链表连接起来, 这就解决了键冲突的问题。

举个例子, 假设程序要将键值对 k2 和 v2 添加到图 4-6 所示的哈希表里面, 并且计算得出 k2 的索引值为 2 , 那么键 k1 和 k2 将产生冲突, 而解决冲突的办法就是使用 next 指针将键 k2 和 k1 所在的节点连接起来, 如图 4-7 所示。

              Redis 解决键冲突

Redis 解决键冲突

因为 dictEntry 节点组成的链表没有指向链表表尾的指针, 所以为了速度考虑, 程序总是将新节点添加到链表的表头位置(复杂度为 Redis 解决键冲突), 排在其他已有节点的前面。

详见:https://www.w3cschool.cn/hdclil/dkqjvozt.html

https://blog.csdn.net/qq_25484147/article/details/78641392

相关文章:

  • 2022-01-16
  • 2021-09-21
  • 2021-05-31
  • 2021-12-29
  • 2021-10-18
  • 2021-12-20
  • 2021-08-08
猜你喜欢
  • 2022-12-23
  • 2022-01-21
  • 2021-07-31
  • 2021-10-15
  • 2018-12-06
  • 2022-01-09
相关资源
相似解决方案