java 中的 Comparable 和 Comparator 与 Iterable 和 Iterator
Comparable 和 Comparator
1、Comparable<T> 比较的是当前值与另一个值。
public interface Comparable<T> { public int compareTo(T o); }
举例:
Date dt = new Date(); // 默认计算从标准时间为止的毫秒数,也可以指定初始时间 Date dt2 = new Date(2222L); // -1 表示小于,0表示等于,1表示相等 System.out.println(dt.compareTo(dt2)); // 1
2、Comparator 是一个函数式接口,目的是提供将两个值进行比较的方法,参数是两个值。
@FunctionalInterface public interface Comparator<T> { int compare(T o1, T o2); //... }
举例:
List<Integer> lt = new ArrayList<>(); lt.add(2); lt.add(8); lt.add(3); lt.sort((t1, t2) -> t1 < t2 ? 1 : (t1.equals(t2) ? 0 : -1)); /*lt.sort(new Comparator<Integer>() {*/ /* @Override*/ /* public int compare(Integer t1, Integer t2) {*/ /* return t1 < t2 ? 1 : (t1.equals(t2) ? 0 : -1);*/ /* }*/ /*});*/ System.out.println(lt);
Iterable 和 Iterator
接口 Iterable<T> 实现这个接口允许对象成为 "foreach" 语句的目标。
注意:由于 java中没有 Array类,所以数组中没有实现 Iterable 接口,但是它可以使用 foreach方式遍历。
而其核心方法就是 iterator ,该方法的返回值为 Iterator<T> 对象。通过Iterator 对象的hasNext()与 next() 方法实现遍历。
从某种角度来说,foreach 是 iterator的简单语法糖(一种形式):
List<Integer> lt = new ArrayList<>(4); lt.add(2); lt.add(9); lt.add(3); for (int i : lt) { System.out.println(i); } Iterator<Integer> itor = lt.iterator(); while (itor.hasNext()) { Integer i = itor.next(); System.out.println(i); }
注意:当直接使用 iterator 时,注意在 while方法体内不能调用对集合调用任何 modify形式的方法 (如 add,remove,clear 等方法),否则抛出 ConcurrentModificationException 异常,但是可以调用 iterator 对象的本身的 remove方法。
foreach 同理,但可以在只使用 while 遍历,而不使用 iterator的循环中使用 modify形式的方法。