java.util包学习笔记一

王朝java/jsp·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

学习java2SDK 1.4.0 java.util里边有几个重要的接口,列在这里作为学习的总结:

1 java.util.Enumeration

有两个方法hasMoreElements(),nextElement()。使用方法如下:

//打印向量v的所有元素

for(Enumeratin e = v.elements(); e.hasMoreElements();){

System.out.println(e.nextElement().toString());

}

这里注意要调用nextElement()首先要判断是否容器里还有元素,若不判断在容器无下一元素时会抛出

NoSuchElementException异常。

当然要想遍历向量中的元素,还可以用Vector的size()和elementAt(int)两个方法,但总觉得还是这里的

以及下面的方法要好(没测试过,大家可以讨论)

注:java.util包里实现该接口的只有java.util.StringTokenizer类。

2 java.util.Iterator

有三个方法hasNext(),next(),remove()。Iterator接口是用来取代Enumeration接口在java集合框架中的应用

与Enumeration的区别:多了个remove()方法,方法名字不同。使用方法如下:

//打印向量v除了值为“a“的所有元素

import java.util.*;

public class test{

public static void main(String[] args){

Vector v = new Vector(4);

v.add("a");

v.add("b");

v.add("c");

v.add("d");

for(Iterator iter = v.iterator();iter.hasNext();){

if(iter.next().equals("a"))iter.remove();

else System.out.println(iter.next().toString());

}

}

}

运行结果我吃了一惊:只打出一个值c,而且抛出异常NoSuchElementException

原因:第一次循环调用iter.next()值为a,调用iter.remove()将其删除,正确。

第二次循环调用iter.next()值为b,进入else语句,又调用一次iter.next()值为c打印

第三次循环调用iter.next()值为d,进入else语句,此时向量v中已无更多元素,再调用next()

则抛出异常。

结论:如同Enumeration接口一样,每次调用next(),都要想调用hasNext(),而且你必须防止调用了

一次hasNext(),而后边多次调用next();

remove()方法只能删除next()方法所指定的元素,如果你不调用next(),你就不应调用remove()

否则会抛出IllegalStatementException,也就是说你不能用下面的代码完成类似

要清空集合里所有的元素

for(Iteraor iter = v.iterator(); iter.hasNext();){

iter.remove();

}

注:java集合Collection里边有个iterator()方法,返回一个Iterator.而具体实现取决于实现该接口的类。

比如AbstractCollection里有个private class itr实现了Iterator,而iterator()方法返回的就是这个itr。

所有实现了Collection接口的类都可以直接调用iterator()

ArrayList, LinkedList, vector, HashSet, TreeSet

3 java.util.Comarator

有两个方法:int compare(object o1, object o2), boolean equals(object o)

前者分别用正,零,负表示两个对象排序规则中的领先,相等,落后

后者判断两对象是否相等

注:实现该接口的类为Collator。另外“effective java“一书对这个接口好象有很详细的描述

4 java.util.RandomAccess

这只是个标志接口,用于表明实现该接口的类支持fast(generally constant time) random access。

我的理解是即查找元素的时间与容器里元素的多少无关,可以用下标来取元素。以下是jdk中

给的一个比较:

for(int i = 0, int n = list.size(); i < n; i++)

list.get(i);

for(Iterator iter = list.iterator(); iter.hasNext();)

list.next();

前者运行起来要比后者快

注:实现该接口的类有ArrayList, Vector

5 java.util.EventListener

标志接口,所有事件监听者接口必须扩展的接口

6 java.util.Observer看不懂实际中怎么用:(

最复杂的Collection和Map接口下次再学吧,饿死了

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航