- 主要区别在于:线程安全性,同步(synchronization),以及速度。
线程安全性方面: HashMap是几乎等价于HashTable的,HashTable是比较老版本的,Jdk5以后提供了ConcurrentHashMap,用来替代HashMap,它比HashMap的扩展性更好。
HashMap的迭代器是fail-fast迭代器,而HashTable的是enumerator迭代器,所以当线程改变了HashMap的机构,就会抛出ConcurrentModificationExection异常,但是迭代器本身的remove()方法移除元素就不会抛出异常
速度:
由于HashTable是线程安全的,所以在单线程环境下它的执行速递要慢与HashMap
HashMap和HashTable的区别
最新推荐文章于 2023-09-02 16:42:32 发布