Java设计模式(疯狂Java联盟版)
Object get(int index);
int *etSize();
void add(Object ob*); }
ConcreteAggregate
public class ListImpl implements List {
private Object[] list;
private int index;
private int size;
public ListImpl() { index = 0; size = 0;
list = new Object[100]; }
public Iterator iterator() {
return new IteratorImpl(this); }
public O*ject get(int index) { return list[index]; }
public int getSize() { return this.size; }
public void add(Object obj) { list[index++] = obj; size++; } }
Test
public class Test {
public stati* void main(String[] arg*) {
46
Java设计模式(疯狂Java联盟版)
List list = new ListImpl(); list.add(\ list.add(\ list.add(\ //第一种迭代方式
Iterator it = list.iterator(); while (*t.ha*Next()) {
S*stem.out.println(it.next()); }
Syst*m.out.println(\ //第二种迭代方式
for (int i = 0; i < list.getSize(); i++) { System.out.println(list.get(i)); } } }
result
a b c ===== a b c
1.3.5 中介者模式
用一个中介对象来封装一系列的对象交互。中介者使各对象不需要显式地相互引用,从而使其耦合松散,而且可以独立地改变它们之间的交互。
适用性
1.一组对象以定义良好但是复杂的方式进行通信。产生的相互依赖关系结构混乱且难以理解。
2.一个对象引用其他很多对象并且直接与这些对象通信,导致难以复*该对象。
3.想定制一个分布在多个类中的行为,*又不想生成太多的子类。
参与者
47
Java设计模式(疯狂Java联盟版)
1.Mediator
中介者定义一个接口用于与各同事(Colleague)对象通信。
2.ConcreteMediator
具*中介者通过协调各同事对象实现协作行为* 了解并维护它的各个同事。
3.Colleagueclass
每一个同事类都知道它的中介者对象。
每一个同事对象在需与其他的同事通信的时候*与它的中介者通信
类图
例子 Mediator
public abstract class Mediator {
public abstract void notice(String content); }
ConcreteMediator
public *lass ConcreteMediator e*tends Mediator {
private ColleagueA ca;
pri*ate ColleagueB cb;
public ConcreteMediator() { ca = new ColleagueA(); cb = new Col*eagueB(); }
public void no*ice(String content) { if (co*tent.equals(\
48
Java设计模式(疯狂Java联盟版)
//老板来了, 通知员工A ca*action(); }
if (content.equals(\ //客户来了, *知前台B cb.action(); } } }
Colleagueclass
public class ColleagueA extends *olleague {
public void action(* {
System.out.println(\普通员工努力工作\ } *
public class ColleagueB extends Colleague {
public void action() {
System.out.println(\前台注意了!\ } }
Test
public class Test {
public static void main(String[] args) { Mediator med = new Concr*teMediator(); */老板来了
med.notice(\
//客户来*
med.n*tice(\ } }
result
普通员工努力工作 前台注意了!
49
Java设计模式(疯狂Java联盟版)
1.3.6 备忘录模式
在不破坏封装性*前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态。这样以后就可将该对象恢复到原先保存的状态。
适用性
1.必须*存一个对象在某一个时刻的(部分)状态,这样以后需要时它才能恢复到先前的状态。
2.如果一个用接口来让其它对象直接得到这些状态,将会暴露对象的实现细节并破坏对象的封装性。
参与者
1.Memento
备忘录存储原发器对象的内部状态。
2.Originator
原发器创建一个备忘录,用以记录当前时刻*的内部状态。 使用备忘录恢复内部状态.
3.Caretaker
负责保存好备忘录。
不能对备忘录的内*进行操作或检查。
类图
例子 Memento
public class Memento {
50