Java核心API -- 7(Iterator迭代器、Comparable、Comparator比较器)

1. Iterator迭代器

所有Collection的实现类都实现了iterator方法,该方法返回一个Iterator接口类型的对象,用于实现对集合元素迭代的便利。在java.util包下。

1)Iterator定义有三个方法:

①boolean hasNext()方法:判断指针后面是否有元素。

②E next()方法:指针后移,并返回当前元素。E代表泛型,默认为Object类型。

③void remove()方法:在原集合中删除刚刚返回的元素。

2)对于List集合而言,可以通过基于下标的get方法进行遍历;而iterator方法是针对Collection接口设计的,所以,所有实现了Collection接口的类,都可以使用Iterator实现迭代遍历。

3)迭代器的使用方式:先问后拿。问:boolean hasNext()该方法询问迭代器当前集合是否还有元素;拿:E next()该方法会获取当前元素。迭代器的迭代方法是while循环量身定制的。

4)迭代器中的删除问题:在迭代器迭代的过程中,我们不能通过“集合”的增删等操作,来改变该集合的元素数量!否则会引发迭代异常!若想删除迭代出来的元素,只能通过Iterator。迭代器在使用自己的remove()方法时,可以将刚刚获取的元素从集合中删除,但是不能重复调用两次!即在不迭代的情况下,不能在一个位置删两次。



案例9:



2. Comparable和Comparator接口

(1) Comparable接口:Comparable接口用于表示对象间的大小关系,我们需要实现Comparable接口,并重写compareTo()方法定义比较规则。

(2) Collections.sort()方法:需要集合中的对象实现Comparable接口,从而可以调用其compareTo方法判断对象的大小,否则sort将无法判断。该方法会依次调用集合中每个元素的compareTo方法,并进行自然排序。



案例10:



(3) Comparator接口:比较器。一旦Java类实现了Comparable,其比较逻辑就已经确定了,如果希望在排序中的操作按照“临时指定规则”,即自定义比较规则。可以采用Comparator接口回调方式。使用匿名类方式创建一个实例来定义比较器的方式很常见。

Comparator比较器创建步骤:

①定义一个类并实现Comparator接口。

②实现接口中的抽象方法compare(E o1,E o2)。

③实例化这个比较器

④调用Collections的重载方法:sort(Collection c,Comparator comparator)进行排序。



案例11:



3. Collection和Collentions的区别

Collection是java.util下的接口,它是各种集合的父接口,继承于它的接口主要有Set 和List;

Collections是个java.util下的类,是针对集合的帮助类,提供一系列静态方法实现对各种集合的搜索、排序、线程安全化等操作。

时间: 2024-08-24 21:42:18

Java核心API -- 7(Iterator迭代器、Comparable、Comparator比较器)的相关文章

Java核心API需要掌握的程度

分类: java技术2009-08-29 01:03 213人阅读 评论(0) 收藏 举报 javaapiswingxmlio Java的核心API是非常庞大的,这给开发者来说带来了很大的方便,经常人有评论,java让程序员变傻. 但是一些内容我认为是必须掌握的,否则不可以熟练运用java,也不会使用就很难办了. 1.java.lang包下的80%以上的类的功能的灵活运用. 2.java.util包下的80%以上的类的灵活运用,特别是集合类体系.正规表达式.时间.属性.和Timer. 3.jav

Java的集合、Iterator迭代器

1.集合(1)集合存储的元素必须是引用类型数据[自动装箱(基本类型->包装类)]jdk1.5版本之后 建立一个  demo01  类 package com.oracle.demo01; public class demo01 { private String name; private Integer age; public demo01() { super(); } public demo01(String name, Integer age) { super(); this.name =

Java核心API -- 6(Collection集合List、Set、ArrayList、HashSet)

1. Collection集合框架 Java.util.Collection接口 |--List子接口 |--ArrayList实现类 |--LinkedList实现类 |--Vector实现类 |--Stack(栈,继承Vector,先进后出) |--Set子接口 |--HashSet实现类 |--TreeSet实现类 |--Queue接口(普通队列,先进先出) |--Deque子接口(双端队列) |--ArrayDeque实现类 2. 泛型 1)泛型是 JDK1.5引入的新特性,泛型的本质是

Java核心API -- 2(String、StringBuilder、StringBuffer)

1. String字符串 1)String类型介绍 String类采用final修饰,String对象为不可变对象,一旦在内存中创建,内容不能发生变化,若要对字符串内容改变,那么就会创建新对象. String对象创建,有静态和动态之分. String str1 = "dadsadad"; String str2 = new String("dasdasdadad"); 2)String常量池 JVM对字符串有一个限制,让字符串作为不变对象,这样就可以做到重用.事实上

Java核心API -- 1(Object类)

1. Object类 在Java体系中,java.lang.Object类位于顶端(是所有对象的直接或间接父类).如果一个类没有写extends关键字声明其父类,则该类默认继承java.lang.Object类.Object类定义了"对象"的基本行为,被子类默认继承. 1)toString方法:返回一个可以表示该对象属性内容的字符串. MyObject obj=new MyObject();    // MyObject类自定义 String info=obj.toString();

Java核心API -- 9(异常)

异常处理 异常结构中的父类Throwable类,其下子类Exceptionlei类和Error类.我们在程序中可以捕获的是Exception的子类异常. Error系统级别的错误:Java运行时环境出现的错误,我们不可控. Exception是程序级别的错误:我们可控. 1)捕获异常两种方式: 一是添加try-catch捕获该异常,二是在我们的方法中声明出也追加这种异常的抛出(继续往外抛). 2)异常处理语句:try-catch,如果try块捕获到异常,则到catch块中处理,否则跳过忽略cat

Java核心API -- 12(对象序列化和反序列化)

1. 对象序列化 将一个对象转换为字节形式的过程就是对象序列化.序列化还有个名称为串行化,序列化后的对象再被反序列化后得到的对象,与之前的对象不再是同一个对象. 1)对象序列化必须实现Serializable接口,但该接口无任何抽象方法,不需要重写方法,只为了标注该类可序列化. 2)且同时建议最好添加版本号(编号随便写):serialVersionUID.版本号,用于匹配当前类与其被反序列化的对象是否处于同样的特征(属性列表一致等).反序列化时,ObjectInputStream会根据被反序列化

Java核心API -- 10(File、RandomAccessFile)

1. File文件类 java使用File类(java.io.File)表示操作系统上文件系统中的文件或目录.换句话说,我们可以使用File操作硬盘上的文件或目录进行创建或删除. File可以描述文件或目录的名字,大小等信息,但不能对文件的内容操作!File类的构造器都是有参的. 1)关于路径的描述:不同的文件系统差异较大,Linux和Windows就不同!最好使用相对路径,不要用绝对路径. 2)"."代表的路径:当前目录(项目所处的目录),在eclipse_workspace/pro

Java核心API -- 8(Map集合)

1. Map集合 Java.util.Map接口 |--HashMap实现类 |--TreeMap实现类 2. HashMap实现类 Map接口定义的集合又称为查找表,用于存储所谓"Key-Value"键值对.Key可以看成是Value的索引.而往往Key是Value的一部分内容. 1)Key不可以重复,但所保存的Value可以重复. 2)根据内部结构的不同,Map接口有多种实现类,其中常用的有内部为hash表实现的HashMap和内部为排序二叉树实现的TreeMap.同样这样的数据结