Java设计模式之访问者模式

转载 2015年07月10日 15:15:38

转载

原创此处

主题

定义
封装某些作用于某种数据结构中各元素的操作,它可以在不改变数据结构的前提下定义作用于这些元素的新的操作。

java

class A {    
    public void method1(){    
        System.out.println("我是A");    
    }    

    public void method2(B b){    
        b.showA(this);    
    }    
}    

class B {    
    public void showA(A a){    
        a.method1();    
    }    
}

看一下在类A中,方法method1和方法method2的区别在哪里,方法method1很简单,就是打印出一句“我是A”;方法method2稍微复杂一点,使用类B作为参数,并调用类B的showA方法。再来看一下类B的showA方法,showA方法使用类A作为参数,然后调用类A的method1方法,可以看到,method2方法绕来绕去,无非就是调用了一下自己的method1方法而已,它的运行结果应该也是“我是A”,分析完之后,我们来运行一下这两个方法,并看一下运行结果:

java

public class Test {    
    public static void main(String[] args){    
        A a = new A();    
        a.method1();    
        a.method2(new B());    
    }    
}  

运行结果为:

我是A
我是A

角色分析

在例子中,对于类A来说,类B就是一个访问者。
抽象访问者:抽象类或者接口,声明访问者可以访问哪些元素,具体到程序中就是visit方法中的参数定义哪些对象是可以被访问的。
访问者:实现抽象访问者所声明的方法,它影响到访问者访问到一个类后该干什么,要做什么事情。
抽象元素类:接口或者抽象类,声明接受哪一类访问者访问,程序上是通过accept方法中的参数来定义的。抽象元素一般有两类方法,一部分是本身的业务逻辑,另外就是允许接收哪类访问者来访问。
元素类:实现抽象元素类所声明的accept方法,通常都是visitor.visit(this),基本上已经形成一种定式了。
结构对象:一个元素的容器,一般包含一个容纳多个不同类、不同接口的容器,如List、Set、Map等,在项目中一般很少抽象出这个角色。

抽象元素类

java

abstract class Element {    
    public abstract void accept(IVisitor visitor);    
    public abstract void doSomething();    
}   

元素类

java

class ConcreteElement1 extends Element {    
    public void doSomething(){    
        System.out.println("这是元素1");    
    }    

    public void accept(IVisitor visitor) {    
        visitor.visit(this);    
    }    
}    

class ConcreteElement2 extends Element {    
    public void doSomething(){    
        System.out.println("这是元素2");    
    }    

    public void accept(IVisitor visitor) {    
        visitor.visit(this);    
    }    
}    

抽象访问者

java

interface IVisitor {    
    public void visit(ConcreteElement1 el1);    
    public void visit(ConcreteElement2 el2);    
}  

访问者

java

class Visitor implements IVisitor {    

    public void visit(ConcreteElement1 el1) {    
        el1.doSomething();    
    }    

    public void visit(ConcreteElement2 el2) {    
        el2.doSomething();    
    }    
} 

结构对象

java

class ObjectStruture {    
    public static List<Element> getList(){    
        List<Element> list = new ArrayList<Element>();    
        Random ran = new Random();    
        for(int i=0; i<10; i++){    
            int a = ran.nextInt(100);    
            if(a>50){    
                list.add(new ConcreteElement1());    
            }else{    
                list.add(new ConcreteElement2());    
            }    
        }    
        return list;    
    }    
}  

客户端

java

public class Client {    
    public static void main(String[] args){    
        List<Element> list = ObjectStruture.getList();    
        for(Element e: list){    
            e.accept(new Visitor());    
        }    
    }    
} 

优点
符合单一职责原则:凡是适用访问者模式的场景中,元素类中需要封装在访问者中的操作必定是与元素类本身关系不大且是易变的操作,使用访问者模式一方面符合单一职责原则,另一方面,因为被封装的操作通常来说都是易变的,所以当发生变化时,就可以在不改变元素类本身的前提下,实现对变化部分的扩展。
扩展性良好:元素类可以通过接受不同的访问者来实现对不同操作的扩展。

缺点
增加新的元素类比较困难。通过访问者模式的代码可以看到,在访问者类中,每一个元素类都有它对应的处理方法,也就是说,每增加一个元素类都需要修改访问者类(也包括访问者类的子类或者实现类),修改起来相当麻烦。也就是说,在元素类数目不确定的情况下,应该慎用访问者模式。所以,访问者模式比较适用于对已有功能的重构,比如说,一个项目的基本功能已经确定下来,元素类的数据已经基本确定下来不会变了,会变的只是这些元素内的相关操作,这时候,我们可以使用访问者模式对原有的代码进行重构一遍,这样一来,就可以在不修改各个元素类的情况下,对原有功能进行修改。

适用场景
假如一个对象中存在着一些与本对象不相干(或者关系较弱)的操作,为了避免这些操作污染这个对象,则可以使用访问者模式来把这些操作封装到访问者中去。
假如一组对象中,存在着相似的操作,为了避免出现大量重复的代码,也可以将这些重复的操作封装到访问者中去。

相关文章推荐

java设计模式(三)——模板、访问者、组合、解释器、迭代器、中介者

一、TemplateMethod模板方法模式 模板方法模式是类的行为模式。准备一个抽象类,将部分逻辑以具体方法以及具体构造函数的形式实现, 然后声明一些抽象方法来迫使子类实现剩余的逻辑。不同的子类可以...

访问者设计模式

  • 2015年01月20日 00:53
  • 2.61MB
  • 下载

java设计模式---访问者模式

Java深入到一定程度,就不可避免的碰到设计模式这一概念,了解设计模式,将使自己对java中的接口或抽象类应用有更深的理解.设计模式在java的中型系统中应用广泛,遵循一定的编程模式,才能使自己的代码...

设计模式(二十三)----- 访问者模式(visitor)----(JAVA版)

访问者模式   表示一个作用于某对象结构中的各元素的操作。它使你可以在不改变各元素的类的前提下定义作用于这些元素的新操作。 适用性 1.一个对象结构包含很多类对象,它们有不同的接口,而你想对这些...

java设计模式_访问者模式

一、什么是访问者模式 Visitor模式也叫访问者模式,是行为模式之一 ,它分离对象的数据和行为,使用Visitor模式, 可以不修改已有类的情况下,增加新的操作。 二、访问者模式的应用示例...

访问者模式-java设计模式

在阎宏博士的《JAVA与模式》一书中开头是这样描述访问者(Visitor)模式的:   访问者模式是对象的行为模式。访问者模式的目的是封装一些施加于某种数据结构元素之上的操作。一旦这些操作需要修...

Java设计模式(三) Visitor(访问者)模式及多分派场景应用

基本概念Visitor 封装一些作用于数据结构中的各元素的操作,不同的操作可以借助新的visitor实现,降低了操作间的耦合性 访问者可以将数据结构和对数据的操作解耦,使得增加对数据结构的操作不需要取...

Java设计模式--访问者模式

访问者模式【Visitor Pattern 】以打印公司员工的信息报表为例。下面先看下类图。使用了一个模版方法模式,把所要的信息都打印出来。这样子写出来的代码就不太符合公司不同管理层的需要,不能满足各...

(二十三)Java设计模式之访问者模式

在阎宏博士的《JAVA与模式》一书中开头是这样描述访问者(Visitor)模式的:  访问者模式是对象的行为模式。访问者模式的目的是封装一些施加于某种数据结构元素之上的操作。一旦这些操作需要修改的话,...
  • zbdxcyg
  • zbdxcyg
  • 2017年10月24日 14:55
  • 112
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Java设计模式之访问者模式
举报原因:
原因补充:

(最多只允许输入30个字)