欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

java中Hashtable和HashMap的区别分析

程序员文章站 2023-11-29 14:31:46
1、hashtable是dictionary的子类,复制代码 代码如下: public class hashtable  ...

1、hashtable是dictionary的子类,

复制代码 代码如下:

 public class hashtable<k,v>
     extends dictionary<k,v>
     implements map<k,v>, cloneable, java.io.serializable

hashmap:
复制代码 代码如下:

public class hashmap<k,v>
    extends abstractmap<k,v>
     implements map<k,v>, cloneable, serializable

hashmap和hashtable都是map接口的一个实现类;

2、hashtable中的方法是同步的(),而hashmap中的方法在默认情况下不是同步的。即是说,在多线程应用程序中,不用专门的操作就安全地可以使用hashtable了;而对于hashmap,则需要额外的同步机制。但hashmap的同步问题可通过collections的一个静态方法得到解决:

复制代码 代码如下:

public static <k,v> map<k,v> synchronizedmap(map<k,v> m)

这个方法返回一个同步的map,也就是说返回的map是线程安全的。需要注意的是,对返回的map进行迭代时,必须手动在返回的map上进行同步,否则将会导致不确定的行为:
复制代码 代码如下:

map m = collections.synchronizedmap(new hashmap());
       ...
   set s = m.keyset();  // needn't be in synchronized block
       ...
   synchronized(m) {  // synchronizing on m, not s!
       iterator i = s.iterator(); // must be in synchronized block
       while (i.hasnext())
           foo(i.next());
   }

3.在hashmap中,null可以作为键,这样的键只有一个;可以有一个或多个键所对应的值为null。当get()方法返回null值时,即可以表示hashmap中没有该键,也可以表示该键所对应的值为null。因此,在hashmap中不能由get()方法来判断hashmap中是否存在某个键,而应该用containskey()方法来判断。hashtable的键值不能为null,否则:java.lang.nullpointerexception 。
4.hashtable使用enumeration,hashmap使用iterator。
以上只是表面的不同,它们的实现也有很大的不同。
5.hashtable中hash数组默认大小是11,增加的方式是 old*2+1。hashmap中hash数组的默认大小是16,而且一定是2的指数。
6.哈希值的使用不同,hashtable直接使用对象的hashcode,代码是这样的:

复制代码 代码如下:

int hash = key.hashcode();
int index = (hash & 0x7fffffff) % tab.length;

而hashmap重新计算hash值,而且用与代替求模,比如hashmap的put方法:

复制代码 代码如下:

public v put(k key, v value) {
         if (key == null)
             return putfornullkey(value);
         int hash = hash(key.hashcode());
         int i = indexfor(hash, table.length);
         for (entry<k,v> e = table[i]; e != null; e = e.next) {
             object k;
             if (e.hash == hash && ((k = e.key) == key || key.equals(k))) {
                 v oldvalue = e.value;
                 e.value = value;
                 e.recordaccess(this);
                 return oldvalue;
             }
         }

         modcount++;
         addentry(hash, key, value, i);
         return null;
     }

复制代码 代码如下:

static int hash(int h) {
         // this function ensures that hashcodes that differ only by
         // constant multiples at each bit position have a bounded
         // number of collisions (approximately 8 at default load factor).
         h ^= (h >>> 20) ^ (h >>> 12);
         return h ^ (h >>> 7) ^ (h >>> 4);
     }

复制代码 代码如下:

   static int indexfor(int h, int length) {
         return h & (length-1);
     }