适配器模式实例:反向迭代器

       一般来说,如果我们直接继承Iterable类,并覆盖iterator()方法,我们只能替换现有的方法,而不能实现选择。在这里,我们希望在默认的前向迭代器的基础上,添加一个反向迭代器,因此我们不能使用覆盖,而是添加一个能够产生Iterable对象的方法,该对象可以用于foreach语句,并可以实现反向迭代的功能。

       当我们实现一个接口(前向迭代)并还需要另一个接口的某项功能(反向迭代)时,可以采用适配器模式轻松解决这个问题。代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
package content.ch12;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.Collection;
import java.util.Iterator;

class ReversibleArrayList<T> extends ArrayList<T> {
public ReversibleArrayList(Collection<T> c) {
super(c);
}

public Iterable<T> reversed() {
return new Iterable<T>() {
public Iterator<T> iterator() {
return new Iterator<T>() {
int current = size() - 1;

public boolean hasNext() {
return current > -1;
}

public T next() {
return get(current--);
}

};
}

};
}
}

public class AdapterMethodIdiom {
public static void main(String[] args) {
ReversibleArrayList<String> ral = new ReversibleArrayList<String>(
Arrays.asList("To be or not to be".split(" ")));
// Grabs the ordinary iterator via iterator()
for (String s : ral) {
System.out.print(s + " ");
}
System.out.println();
// Hand it the Iterable of your choice
for (String s : ral.reversed()) {
System.out.print(s + " ");
}
}
}

       输出如下:

1
2
To be or not to be 
be to not or be To

       如果直接将ral对象置于foreach语句中,将得到默认的前向迭代器。但是当我们在该对象上调用reversed()方法得到一个新的自定义的Iterable对象时,就会产生我们自己设定的行为(反向迭代器)。

       来自:《Java编程思想》 第十一章 适配器方法惯用法