服务热线:13616026886

技术文档 欢迎使用技术文档,我们为你提供从新手到专业开发者的所有资源,你也可以通过它日益精进

位置:首页 > 技术文档 > JAVA > 新手入门 > 基础入门 > 查看文档

java.util包学习笔记一


  学习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接口下次再学吧,饿死了

扫描关注微信公众号