继续打卡设计模式
今天来聊一下的是访问者模式
一、实际问题
将观众分为男人和女人,对歌手进行测评,当看完某个歌手表演后,得到他们对该歌手不同的评价(评价 有不 同的种类,比如 成功、失败 等)
这个问题的关键是说对于一个歌手评价而言它的结果是有两个数据属性来共同决定
二、访问者模式来解决
首先我们分析一下这个问题肯定是需要 男人和女人这个类的。抽象一点就是一个人以及对于歌手的评价也是包含男人和女人的评价
所以我们先写一个评价的抽象类
/**
* @author: 德鑫
* Description:
* @Date: 2021/01/27
*/
public abstract class Action {
//得到男性 的测评
public abstract void getManResult(Man man);
//得到女的 测评
public abstract void getWomanResult(Woman woman);
}
那么类里面的形参男人和女人我们
/**
* @author: 德鑫
* Description:
* @Date: 2021/01/27
*/
public abstract class Person {
public abstract void accept(Action action);
}
/**
* @author: 德鑫
* Description:
* @Date: 2021/01/27
*/
public class Man extends Person {
@Override
public void accept(Action action) {
action.getManResult(this);
}
}
/**
* @author: 德鑫
* Description:
* @Date: 2021/01/27
*/
public class Woman extends Person {
@Override
public void accept(Action action) {
action.getWomanResult(this);
}
}
那现在我们的Action评价的子类来分别重写里面的抽象方法
/**
* @author: 德鑫
* Description:
* @Date: 2021/01/27
*/
public class Success extends Action {
@Override
public void getManResult(Man man) {
System.out.println(" 男人给的评价该歌手很成功 !");
}
@Override
public void getWomanResult(Woman woman) {
System.out.println(" 女人给的评价该歌手很成功 !");
}
}
/**
* @author: 德鑫
* Description:
* @Date: 2021/01/27
*/
public class Fail extends Action{
@Override
public void getManResult(Man man) {
System.out.println(" 男人给的评价该歌手失败 !");
}
@Override
public void getWomanResult(Woman woman) {
System.out.println(" 女人给的评价该歌手失败 !");
}
}
/**
* @author: 德鑫
* Description:
* @Date: 2021/01/27
*/
public class Wait extends Action {
@Override
public void getManResult(Man man) {
System.out.println(" 男人给的评价是该歌手待定 ..");
}
@Override
public void getWomanResult(Woman woman) {
System.out.println(" 女人给的评价是该歌手待定 ..");
}
}
对于男人女人可能有多个情况我们创建一个对象结构体
/**
* @author: 德鑫
* Description:
* @Date: 2021/01/27
*/
//对象结构体 表示这个可能管理很多人包括男人和女人
public class ObjectStructure {
private List<Person> persons = new LinkedList<>();
//增加到list
public void attach(Person p) {
persons.add(p);
}
//移除
public void detach(Person p) {
persons.remove(p);
}
//显示测评情况
public void display(Action action) {
for (Person p : persons) {
p.accept(action);
}
}
}
最后写一个客户端测试
/**
* @author: 德鑫
* Description:访问者模式封装了一些作用于某种数据结构的各元素的操作。它可以在不改变原有数据结构的前提下定义作用
*于这些元素操作
*2) 主要将数据结构与数据操作分离,解决 数据结构和操作耦合性问题
*3) 访问者模式的基本工作原理是:在被访问的类里面加一个对外提供接待访问者的接口
*4) 访问者模式主要应用场景是:需要对一个对象结构中的对象进行很多不同操作(这些操作彼此没有关联),同时需要避免让这些操作"污染"这些对象的类,可以选用访问者模式解决
* @Date: 2021/01/27
*/
public class Client {
public static void main(String[] args) {
ObjectStructure objectStructure = new ObjectStructure();
Man man = new Man();
Woman woman = new Woman();
objectStructure.attach(man);
objectStructure.attach(woman);
objectStructure.detach(man);
System.out.println("=======给的是待定的成功========");
Success success = new Success();
objectStructure.display(success);
System.out.println("=======给的是待定的失败========");
Fail fail = new Fail();
objectStructure.display(fail);
System.out.println("=======给的是待定的测评========");
Wait wait = new Wait();
objectStructure.display(wait);
}
}
三、访问者模式的总结
- 访问者模式封装了一些作用于某种数据结构的各元素的操作。它可以在不改变原有数据结构的前提下定义作用于这些元素操作
- 主要将数据结构与数据操作分离,解决 数据结构和操作耦合性问题
- 访问者模式的基本工作原理是:在被访问的类里面加一个对外提供接待访问者的接口
- 访问者模式主要应用场景是:需要对一个对象结构中的对象进行很多不同操作(这些操作彼此没有关联),同时需要避免让这些操作"污染"这些对象的类,可以选用访问者模式解决