通路者模式(Visitor Pattern): 封裝一些作用于某種資料結構的各元素的操作,它可以在不改變資料結構的前提下定義作用于這些元素的新的操作。
主要将資料結構與資料操作分離,解決資料結構和操作耦合性問題。
public abstract class Action {
public abstract void getManResult(Man man);
public abstract void getWomanResult(Woman woman);
}
public class Fail extends Action{
@Override
public void getManResult(Man man) {
System.out.println("男人評價該歌手很失敗");
}
@Override
public void getWomanResult(Woman woman) {
System.out.println("女人評價該歌手很失敗");
}
}
public class Success extends Action{
@Override
public void getManResult(Man man) {
System.out.println("男人評價該歌手很成功");
}
@Override
public void getWomanResult(Woman woman) {
System.out.println("女人評價該歌手很成功");
}
}
public abstract class Person {
public abstract void accept(Action action);
}
// 1. 這裡使用了雙分派, 首先在用戶端程式中, 将具體狀态作為參數傳遞給woman(第一次分派)
// 2. 然後Woman類調用作為參數的"具體方法"中方法getWomanResult,同時将自己(this)作為參數
// 傳入(第2次分派)
public class Woman extends Person{
@Override
public void accept(Action action) {
action.getWomanResult(this);
}
}
public class Man extends Person{
@Override
public void accept(Action action) {
action.getManResult(this);
}
}
import java.util.LinkedList;
import java.util.List;
public class ObjectStructure {
// 維護了一個集合
private List<Person> persons = new LinkedList<Person>();
// 增加到list
public void attach(Person p){
persons.add(p);
}
// 移除
public void remove(Person p){
persons.remove(p);
}
// 顯示測評情況
public void display(Action action){
for(Person p : persons){
p.accept(action);
}
}
}
public class Client {
public static void main(String[] args){
ObjectStructure objectStructure = new ObjectStructure();
objectStructure.attach(new Man());
objectStructure.attach(new Woman());
Success success = new Success();
objectStructure.display(success);
}
}