首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

HashTable、 HashMap、TreeMap差异

2012-12-20 
HashTable、 HashMap、TreeMap区别转自:http://www.zlmind.com/?p679???? 刚开始看到HashTable,HashMap和Tr

HashTable、 HashMap、TreeMap区别

转自:http://www.zlmind.com/?p=679

?

??? 刚开始看到HashTable,HashMap和TreeMap的时候比较晕,觉得作用差不多,但是到实际运用的时候又发现有许多差别的。于是自己搜索了一些相关资料来学习,以下就是我的学习沉淀。
??? java为数据结构中的映射定义了一个接口java.util.Map,而HashMap Hashtable和TreeMap就是它的实现类。Map是将键映射到值的对象,一个映射不能包含重复的键;每个键最多只能映射一个一个值。
??? Hashmap 是一个最常用的Map,它根据键的HashCode 值存储数据,根据键可以直接获取它的值,具有很快的访问速度。HashMap最多只允许一条记录的键为Null;允许多条记录的值为 Null;HashMap不支持线程的同步,即任一时刻可以有多个线程同时写HashMap;可能会导致数据的不一致。如果需要同步,可以用 Collections的synchronizedMap方法使HashMap具有同步的能力.
??? Hashtable 与 HashMap类似,但是主要有6点不同。
??? ??? 1.HashTable的方法是同步的,HashMap未经同步,所以在多线程场合要手动同步HashMap这个区别就像Vector和ArrayList一样。
??? ??? 2.HashTable不允许null值,key和value都不可以,HashMap允许null值,key和value都可以。HashMap允许 key值只能由一个null值,因为hashmap如果key值相同,新的key, value将替代旧的。
??? ??? 3.HashTable有一个contains(Object value)功能和containsValue(Object value)功能一样。
??? ??? 4.HashTable使用Enumeration,HashMap使用Iterator。
??? ??? 5.HashTable中hash数组默认大小是11,增加的方式是 old*2+1。HashMap中hash数组的默认大小是16,而且一定是2的指数。
??? ??? 6.哈希值的使用不同,HashTable直接使用对象的hashCode。

?

?

热点排行