设计模式:访问者模式(Visitor Pattern)
生活随笔
收集整理的這篇文章主要介紹了
设计模式:访问者模式(Visitor Pattern)
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
??訪問者模式(Visitor Pattern): 封裝一些作用于某種數據結構的各元素的操作,它可以在不改變數據結構的前提下定義作用于這些元素的新的操作。
? ?主要將數據結構與數據操作分離,解決數據結構和操作耦合性問題。
? ?訪問者模式的基本工作原理: 在被訪問的類里面加一個對外提供接待訪問者的接口。
?
public abstract class Action {public abstract void getManResult(Man man);public abstract void getWomanResult(Woman woman); }public class Fail extends Action{@Overridepublic void getManResult(Man man) {System.out.println("男人評價該歌手很失敗");}@Overridepublic void getWomanResult(Woman woman) {System.out.println("女人評價該歌手很失敗");} }public class Success extends Action{@Overridepublic void getManResult(Man man) {System.out.println("男人評價該歌手很成功");}@Overridepublic 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{@Overridepublic void accept(Action action) {action.getWomanResult(this);} }public class Man extends Person{@Overridepublic 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>();// 增加到listpublic 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);} }? ? ?
總結
以上是生活随笔為你收集整理的设计模式:访问者模式(Visitor Pattern)的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 数据结构:回溯--解决八皇后问题
- 下一篇: 设计模式:迭代器模式(Iterator