1.HashTable的方法是同步的,HashMap未经同步,所以在多线程场合要手动同步HashMap这个区别就像Vector和ArrayList一样。
[如何手功同步?]
关于详细的手功同步参看文章: http://www.diybl.com/course/3_program/java/javajs/2008515/116888.html
这里是结论:
1、如果 ConcurrentHashMap 够用,则使用 ConcurrentHashMap。
2、如果需自己实现同步,则使用 JDK1.5 提供的锁机制,避免使用 synchronized 关键字。
[JAVA同步的机制]
2.HashTable不允许null值(key和value都不可以),HashMap允许null值(key和value都可以)。
3.HashTable有一个contains(Object value),功能和containsValue(Object value)功能一样。
4.HashTable使用Enumeration,HashMap使用Iterator。
[Enumeration]与[Iterator]的区别?
暂时只找到这一段:
Iterator和enumeration都是用来访问集合的接口.
在Iterator接口中定义了三个方法
1.hasNext() 是否还有下一个元素
2.next() 返回下一个元素
3.remove() 删除当前元素
enumeration只定义了前2个方面,没有remove方法,不具备删除功能.
以上只是表面的不同,它们的实现也有很大的不同。
5.HashTable中hash数组默认大小是11,增加的方式是 old*2+1。HashMap中hash数组的默认大小是16,而且一定是2的指数。
6.哈希值的使用不同,HashTable直接使用对象的hashCode
[hashCode的作用]
[如何手功同步?]
关于详细的手功同步参看文章: http://www.diybl.com/course/3_program/java/javajs/2008515/116888.html
这里是结论:
1、如果 ConcurrentHashMap 够用,则使用 ConcurrentHashMap。
2、如果需自己实现同步,则使用 JDK1.5 提供的锁机制,避免使用 synchronized 关键字。
[JAVA同步的机制]
2.HashTable不允许null值(key和value都不可以),HashMap允许null值(key和value都可以)。
3.HashTable有一个contains(Object value),功能和containsValue(Object value)功能一样。
4.HashTable使用Enumeration,HashMap使用Iterator。
[Enumeration]与[Iterator]的区别?
暂时只找到这一段:
Iterator和enumeration都是用来访问集合的接口.
在Iterator接口中定义了三个方法
1.hasNext() 是否还有下一个元素
2.next() 返回下一个元素
3.remove() 删除当前元素
enumeration只定义了前2个方面,没有remove方法,不具备删除功能.
以上只是表面的不同,它们的实现也有很大的不同。
5.HashTable中hash数组默认大小是11,增加的方式是 old*2+1。HashMap中hash数组的默认大小是16,而且一定是2的指数。
6.哈希值的使用不同,HashTable直接使用对象的hashCode
[hashCode的作用]