|
![]() |
名片设计 CorelDRAW Illustrator AuotoCAD Painter 其他软件 Photoshop Fireworks Flash |
|
学习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接口下次再学吧,饿死了 返回类别: 教程 上一教程: 随机验证码的实现思路 下一教程: JavaScript源代码集锦 您可以阅读与"java.util包学习笔记一"相关的教程: · [学习笔记]Thinking in Java (the 2nd edition) Study Note (4) · java学习笔记 · java学习笔记--Hiding implementation · Java学习笔记(一)--认识开发环境 · Java的“对象思想”学习笔记[二] |
![]() ![]() |
快精灵印艺坊 版权所有 |
首页![]() ![]() ![]() ![]() ![]() ![]() ![]() |