Java设计模式(疯狂Java联盟版)
Test
public class Test {
public static void main(String[] args) { Context ctx = new Context(); ctx.add(new SimpleExpression()); ctx.add(new AdvanceExpression()); ctx.add(new SimpleExpression());
for (Expression eps : ctx.getList()) { eps.interpretectx); } } }
res*lt
这是普通解析器! 这是高级解析器! 这是普通解析器!
1.3.4 迭代器模式
给定一个语言,定义它的文法的一种表示,并定义一个解释器,这个解释器使用该表示来解释语言中的句子。
适用性
1.访问一个聚合对象的内容而无需暴露它的内部表示。 2.支持对聚合对象的多种遍历。
3.为遍历不同的聚合结构提供一个统一的接口(即,支持多态迭代)。
参与者
1.Iterator
迭代器定义访问和遍历元素的接口。 2.ConcreteIterator
具迭代器实现迭代器接口。 对该聚合遍历时跟踪当前位置。 3.Aggregate
聚合定义创建相应迭代器对象的接口。 4.ConcreteAggregate
具体聚合实现创建相应迭代器的接口,该操作返回ConcreteIterator的一个适当的实例.
类图 例子 Iterator
public interface Iterator { Object next(); void first(); void last();
boolean hasNext(); }
ConcreteIterator
30
Java设计模式(疯狂Java联盟版)
public class IteratorImpl implements Iterator { private List list; private int index;
public IteratorImpl(List list) { index = 0;
this.list = list; }
public void first() { index = 0; }
public void last() {
index = list.getSize(); }
public Object next() {
Object obj = list.get(index); index++; return obj; }
public boolean hasNext() {
return index < list.getSize(); } }
Aggregate
public interface List { Iterator iterator(); Object get(int index); int getSize();
void add(Object obj); }
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 Object get(int index) { return list[index]; }
public int getSize() {
31
Java设计模式(疯狂Java联盟版)
return this.size; }
public void add(Object obj) { list[index++] = obj; size++; } }
Test
public class Test {
public static void main(String[] args) { List list = new ListImpl(); list.add(\ list.add(\ list.add(\ //第一种迭代方式
Iterator it = list.iterator(); while (it.hasNext()) {
System.out.println(it.next()); }
System.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.想定制一个分布在多个类中的行为,但又不想生成太多的子类。
32
Java设计模式(疯狂Java联盟版) 参与者 1.Mediator
中介者定义一个接口用于与各同事(Colleague)对象通信。 2.ConcreteMediator
具中介者通过协调各同事对象实现协作行为* 了解并维护它的各个同事。 3.Colleagueclass
每一个同事类都知道它的中介者对象。
每一个同事对象在需与其他的同事通信的时候*与它的中介者通信
类图 例子 Mediator
public abstract class Mediator {
public abstract void notice(String content); }
ConcreteMediator
Public class ConcreteMediator extends Mediator { private ColleagueA ca; private ColleagueB cb;
public ConcreteMediator() { ca = new ColleagueA(); cb = new ColleagueB(); }
public void notice(String content) { if (content.equals(\ //老板来了, 通知员工A ca.action(); }
if (content.equals(\ //客户来了,通知前台B cb.action(); } } }
Colleagueclass
public class ColleagueA extends Colleague { public void action(){
System.out.println(\普通员工努力工作\ } }
public class ColleagueB extends Colleague { public void action() {
System.out.println(\前台注意了!\ } }
33
Java设计模式(疯狂Java联盟版)
Test
public class Test {
public static void main(String[] args) { Mediator med = new ConcreteMediator(); //老板来了
med.notice(\ //客户来了
med.notice(\ } }
result
普通员工努力工作 前台注意了!
1.3.6 备忘录模式
在不破坏封装性的前提下,捕获一个对象的内部状态,并在该对象之外保存这个状态。这样以后就可将该对象恢复到原先保存的状态。
适用性
1.必须保存一个对象在某一个时刻的(部分)状态,这样以后需要时它才能恢复到先前的状态。 2.如果一个用接口来让其它对象直接得到这些状态,将会暴露对象的实现细节并破坏对象的封装性。
参与者
1.Memento
备忘录存储原发器对象的内部状态。 2.Originator
原发器创建一个备忘录,用以记录当前时刻的内部状态。 使用备忘录恢复内部状态. 3.Caretaker
负责保存好备忘录。
不能对备忘录的内进行操作或检查。
类图 例子 Memento
public class Memento { private String state;
public Memento(String state) { this.state = state; }
public String getState() { return state; }
public void setState(String state) { this.state = state;
34