访问者模式

1解决问题:

有稳定的数据结构,易变的算法。

换句话说,就是被处理的对象就那么多(稳定的数据结构),而对这些对象,可能有不同的操作(易变的算法),每种算法作用于每类对象上都产生不同结果。


数据结构就是“元素”

算法就是“访问者”


如果在数据结构上判断“究竟是那个操作作用用它”,那么会有很长的if-else,不好。

而且操作的数量很可能变化,此时就需要改变“数据结构”里的if-else

 

2解决方法:

调用点由“元素”内部转向“访问者内部”

即 原来是:

我是元素A,如果我收到了访问命令x,那么我。。。。,如果我收到了命令y,那么我。。。。

现在是:

我是命令x,如果我去作用于元素A,那么它。。。。,如果我作用于元素B,那么它。。。。


由于元素的个数稳定 且远少于 命令(访问者)的个数

所以此时在访问者内部的“分支判断”就很小,甚至更好的做法是直接用不同的函数区分的。

 

 

3

public interface AbstractElement {
	public  void accept(AbstractVisitor v);
}

 

public class ElementA implements AbstractElement{

	public void accept(AbstractVisitor v) {
		v.visitElementA(this);
	}
	
	public String getName(){
		return "aaa";
	}
}
 
public class ElementB implements AbstractElement{

	public void accept(AbstractVisitor v) {
		v.visitElementB(this);
	}
	
	public String getName(){
		return "bbb";
	}
}
 
public interface AbstractVisitor {
	public void visitElementA(ElementA a);
	public void visitElementB(ElementB b);
}
 
public class VisitorA implements AbstractVisitor{

	public void visitElementA(ElementA a) {
		System.out.println("visitor a visit element a,then a will do sth:" + a.getName());
	}

	public void visitElementB(ElementB b) {
		System.out.println("visitor a visit element b,then b will do sth:" + b.getName());
	}
}
 
public class VisitorB implements AbstractVisitor{

	public void visitElementA(ElementA a) {
		System.out.println("visitor b visit element a,then a will do sth:" + a.getName());
	}

	public void visitElementB(ElementB b) {
		System.out.println("visitor b visit element b,then b will do sth:" + b.getName());
	}
}
 
public class ObjectStructure {
	public List<AbstractElement> elements = new LinkedList<AbstractElement>();
	public void attach(AbstractElement e){
		elements.add(e);
	}
	public void detach(AbstractElement e){
		elements.remove(e);
	}
	
	public void acceptAll(AbstractVisitor v){
		for(AbstractElement e : elements){
			e.accept(v);
		}
	}
}
 
public class Demo {
	public static void main(String[] args) {
		ObjectStructure o = new ObjectStructure();
		AbstractElement e1 = new ElementA();
		AbstractElement e2 = new ElementB();
		
		AbstractVisitor v1 = new VisitorA();
		AbstractVisitor v2 = new VisitorB();
		
		o.attach(e1);
		o.attach(e2);
		
		o.acceptAll(v1);
		o.acceptAll(v2);
	}
}
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值