3、HashMap与HashTable

一、

数组:

存储区间是连续的,占内存严重

易查找、插入删除困难

链表:

存储区间是离散的,占内存少

难查找,插入删除容易

哈希表:

查找易、插入删除也易

原理:

hash表是由 数组+链表 组成的

一个长度为16的数组中,每个元素存储的是一个链表的头结点。这些元素是按照什么样的规则存储到数组中呢。一般情况是通过hash(key)%len获得,也就是元素的key的哈希值对数组长度取模得到。比如上述哈希表中,12%16=12,28%16=12,108%16=12,140%16=12。所以12、28、108以及140都存储在数组下标为12的位置。

首先HashMap里面实现一个静态内部类Entry,其重要的属性有 key , value, next,从属性key,value我们就能很明显的看出来Entry就是HashMap键值对实现的一个基础bean,我们上面说到HashMap的基础就是一个线性数组,这个数组就是Entry[],Map里面的内容都保存在Entry[]里面。

二、

Hashtable 继承自 Dictionary 而 HashMap继承自AbstractMap

hashtable线程安全、hashMap线程不安全,所以hashmap效率要稍微高一些

HashMap是Hashtable的轻量级实现(非线程安全的实现),他们都完成了Map接口,

主要区别在于HashMap允许空(null)键值(key),由于非线程安全,效率上可能高于Hashtable。

HashMap允许将null作为一个entry的key或者value,而Hashtable不允许。

猜你喜欢

转载自my.oschina.net/u/3551274/blog/1791058