HashMap和Hashtable的区别

原文 标签 IT工具网 java

问题

在Java中HashMapHashtable的区别? 哪一个对于多线程应用程序更好?

回答

  1. Hashtable是同步的,加了synchronized锁,而HashMap不是。没有加synchronized锁的对象,性能通常比加了synchronized锁的对象要更好一些,因此,如果是非多线程程序,不需要考虑锁、同步等问题,那么使用HashMap更好。
  2. Hashtable不允许有空的键或值。HashMap允许空键和空值。
  3. HashMap有一个子类LinkedHashMap,对这个类对象进行迭代时,它的顺序是有序的(按插入顺序排序)。如有需要,你也能轻易的从LinkedHashMap转化成HashMapHashtable就没那么简单了,

总之,如果你无需关心同步(synchronized)问题,我会建议用HashMap。反之,你可以考虑使用ConcurrentHashMap

stackoverflow链接:

http://stackoverflow.com/questions/40471/differences-between-hashmap-and-hashtable

相关推荐:

importnew:HashMap和Hashtable的区别

相关文章:

java为什么不能用string类型进行switch判断

为什么Java的Vector类被认为是过时的或者废弃的

什么在java中存放密码更倾向于char[]而不是String

java - "Double Brace Initialization"的效率问题

java - glassfish 的错误 500

什么是JavaScript严格模式?

java - 正则表达式从路径中去除所有目录名(保留文件名)

java - 如何解决Base64DecodingException:它应该被java中的四个错误整除?

java - 更新包含对象字段的实体

java - 如何使用PROJ.4将坐标从WGS84转换为投影中的坐标?