0%

hash

Hash

摘要

数据结构基本分为

  • 结构体(或对象)
  • 数组
  • 链表

哈希函数

Hash也叫散列,hash操作其本质上就是建给一个数据映射成另一个数据,通常情况下原数据的长度
比hash后的数据容量大。这种映射关系我们称为哈希函数。
通常 哈希函数的输入要远远多于哈希值所表示的总数,就有可能两个不同的输入对应同一个哈希值。
通常把具有不同关键码而具有相同哈希值的记录称为“同义词”。

哈希表

哈希表是一种数据结构,实现key-value的快速存取。

HasshCode

  • 相等的对象必须要有相同的哈希码。
  • 不相等的对象可能会存在相同的哈希码。
  • 有同一个哈希值的对象不一定相等。
    HashCode 不可信,因此不要将 HashCode 作为key。
    使用基于哈希的算法,比如 SHA1 。来降低hashcode的冲突。

HashTable

HashMap

线程不安全的原因

因为在自动调整大小的机制下,如果线程试着去添加或者获取一个对象,Map可能会使用旧的索引值,
这样就不会找到Entry对象所在的新桶。

保证线程安全的HashMap实现:ConcurrentHashMap。对于ConcurrentMap来说,只有桶是同步的,
这样如果多个线程不使用同一个桶或者调整内部数组的大小,它们可以同时调用get(),remove(),
或者put()方法。