这个类,在使用上和HashMap的区别不大,其方法都是同步的(Synchronized).
- package collection.lession13;
- import java.util.Hashtable;
- /**
- * 老紫竹JAVA提高教程(13)-认识Map之Hashtable<br>
- * 这个类继承自一个已经过期不推荐使用的Dictionary类<br>
- * 目前均推荐实现Map接口<br>
- *
- *
- * @author 老紫竹 JAVA世纪网(java2000.net)
- *
- */
- public class Lession13Hashtable {
- public static void main(String[] args) {
- // Hashtable的默认容量为11 ,从源代码可以清楚的看到
- // public Hashtable() {
- // this(11, 0.75f);
- // }
- // 而 HashMap的默认容量为16
- // 他们的加载因子都是0.75
- Hashtable ht = new Hashtable();
- // 我们先测试一下是否允许key为null;
- try {
- ht.put(null, "测试null的键");
- System.out.println("OK! Hashtable 允许key为null");
- } catch (NullPointerException ex) {
- System.out.println("ERROR! Hashtable 不允许key为null");
- }
- // 我们再先测试一下是否允许value为null;
- try {
- ht.put("测试null的值", null);
- System.out.println("OK! Hashtable 允许value为null");
- } catch (NullPointerException ex) {
- System.out.println("ERROR! Hashtable 不允许value为null");
- }
- // 从测试接口可以看到,Hashtable不允许key或者value为null
- // 其它的操作,和HashMap区别不大,就不再多写了。
- }
- }
如果你前面熟悉了HashMap,那么你可以简单的把Hashtable看成不允许null的同步的HashMap就行了。
内部虽然有一些不同,但对于普通的使用来说,影响不大,可以忽略。