区别:
- 历史原因:Hashtable是基于陈旧的Dictionary类的,HashMap是Java1.2引进的Map接口的一个实现。
- 同步性:Hashtable是同步的。保证了Hashtable中的对象是线程安全的。而HashMap则是异步的,因此HashMap中的对象是线程不安全的。因为同步的要求会影响执行的效率,所以如果你不需要线程安全的集合,那么使用HashMap是一个很好的选择,这样可以避免因为同步带来的不必要的时间损耗。
- 值:HashMap可以让你将空值作为一个表的Key或者Value,但是Hashtable是不能放入空值的(null)。
简单介绍同步性:
如果具有同步性,那么在线程中,就只能有一个线程可以访问它。当一个线程访问它的时候,它会用内部锁将其封锁,其他线程要访问的时候,需要按照顺序进行依次访问,就好像排队购票一个意思,一个窗口只能服务一个人,不然挤着购票容易出错。
如果不具有同步性,那么多个线程可以同时访问,不修改数据还好,当一个线程正在修改数据,另一个线程正在取出数据,你能保证第二线程取的是修改前还是修改后的数据吗?哈哈哈。但是因为这个可以多线程访问,所以访问特别快。
总结:
在需要保证线程安全的时候,要用Hashtable,在不需要线程安全的时候用HashMap。Hashtbale比较慢,HashMap特别快。
欢迎各位在评论区留言讨论~~