欢迎来到代码驿站!

JAVA代码

当前位置:首页 > 软件编程 > JAVA代码

java HashMap和HashTable的区别详解

时间:2021-03-13 09:50:37|栏目:JAVA代码|点击:

  HashMap和HashTable,这二者的区别经常被别人问起,今天在此总结一下。

(一)继承的历史不同

public class Hashtable extends Dictionary implements Map
public class HashMap extends AbstractMap implements Map

    Hashtable是继承自Dictionary类的,而HashMap则是Java 1.2引进的Map接口的一个实现。

(二)安全性不同

    HashMap是非synchronized,而HashTable在默认的情况下是synchronized,这意味着HashTable是线程安全的,多个线程可以共享一个HashTable;而如果没有正确的同步的话,多个线程是不能共享HashMap的。Java 5以后提供了ConcurrentHashMap,它是HashTable的替代,比HashTable的扩展性更好。当然,我们可以通过以下方法让HashMap同步:

Map m = Collections.synchronizeMap(hashMap);

(三)是否可为空值的异同

    HashMap可以让你将空值作为一个表条目的key或value。HashMap中只有一条记录可以是一个空的key,但任意数量的条目可以是空的value。这就是说,如果在表中没有发现搜索键,或者如果发现了搜索键,但它是一个空的值,那么get()将返回null;而HashTable则不行,key和value都不允许出现null值。

(四)二者的遍历方式的内部实现上不同

    Hashtable、HashMap都使用了 Iterator迭代器,HashMap的迭代器(Iterator)是fail-fast迭代器,而HashTable的enumerator迭代器不是fail-fast的。而由于历史原因,Hashtable还使用了Enumeration的方式 。

(五)哈希值的使用不同

    HashTable直接使用对象的hashCode,而HashMap则需要重新计算hash值。

(六)二者内部实现方式的数组的初始大小和扩容的方式不同

    HashTable中hash数组默认大小是11,增加的方式是 old*2+1;HashMap中hash数组的默认大小是16,而且一定是2的指数。

感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!

上一篇:java实现简单超市管理系统

栏    目:JAVA代码

下一篇:java Beanutils.copyProperties( )用法详解

本文标题:java HashMap和HashTable的区别详解

本文地址:http://www.codeinn.net/misctech/80163.html

推荐教程

广告投放 | 联系我们 | 版权申明

重要申明:本站所有的文章、图片、评论等,均由网友发表或上传并维护或收集自网络,属个人行为,与本站立场无关。

如果侵犯了您的权利,请与我们联系,我们将在24小时内进行处理、任何非本站因素导致的法律后果,本站均不负任何责任。

联系QQ:914707363 | 邮箱:codeinn#126.com(#换成@)

Copyright © 2020 代码驿站 版权所有