23种设计模式之访问者模式(Visitor Pattern)
本篇文章将23种设计模式中的访问者模式,此篇文章为一天学习一个设计模式系列文章,后面会分享其他模式知识。
前言:大家好,我是小威,24届毕业生,在一家满意的公司实习。本篇文章将23种设计模式中的访问者模式,此篇文章为一天学习一个设计模式系列文章,后面会分享其他模式知识。
如果文章有什么需要改进的地方还请大佬不吝赐教👏👏。
小威在此先感谢各位大佬啦~~🤞🤞
🏠个人主页:小威要向诸佬学习呀
🧑个人简介:大家好,我是小威,一个想要与大家共同进步的男人😉😉
目前状况🎉:24届毕业生,在一家满意的公司实习👏👏💕欢迎大家:这里是CSDN,我总结知识的地方,欢迎来到我的博客,我亲爱的大佬😘
以下正文开始
访问者模式概念
访问者模式是一种行为型设计模式,它将算法与其所作用的对象分离开来,使得能够在不改变对象结构的前提下,对对象中的元素进行新的操作。该模式的核心思想是,定义一个访问者对象,并将其传递给需要被访问的对象,在对象接受访问者的访问时,会调用访问者对象中的方法,在该方法中实现对象对于访问者的响应操作。
访问者模式主要角色
访问者模式中的主要角色包括:
抽象访问者(Visitor):定义了访问者可以访问的元素、如何访问元素的方法,不同的具体访问者可以实现不同的访问方式。
具体访问者(ConcreteVisitor):实现抽象访问者中定义的方法,对元素进行具体的操作。
抽象元素(Element):定义了接受访问者访问的方法,不同的具体元素可以实现该方法以不同的方式响应访问者的访问。
具体元素(ConcreteElement):实现抽象元素中定义的接受访问者访问的方法,并在其中调用访问者的访问方法。
对象结构(Object Structure):定义了具体元素的集合,并提供了遍历集合中元素的方法。
访问者优缺点
访问者模式的优点包括:
将算法与对象结构分离,可以灵活地添加新的访问者和元素类型。
符合单一职责原则,使得代码更加清晰、易于维护。
访问者模式的缺点包括:
增加新的元素类型会导致访问者的实现类数量增加,系统的复杂度会增加。
具体元素暴露了访问者所需的所有细节,增加了对象间的依赖关系。
访问者案例
假设有一个图形绘制程序,它支持图形对象的添加、删除以及移动等操作。其中包含三种图形对象:圆形、矩形和三角形。
首先需要定义抽象元素接口 Shape,它包含了接受访问者 visit() 方法的定义:
public interface Shape {
void accept(Visitor visitor);
}
每一个具体的图形对象都需要实现该接口,并在其中调用访问者对象中相应的操作方法。例如,圆形类实现如下:
public class Circle implements Shape {
private int x;
private int y;
private int radius;
public Circle(int x, int y, int radius) {
this.x = x;
this.y = y;
this.radius = radius;
}
public void accept(Visitor visitor) {
visitor.visitCircle(this);
}
// ...
}
其中的 accept() 方法中的参数 visitor 是访问者对象,它的 visitCircle() 方法是针对圆形对象的处理方法。
接下来需要定义抽象访问者接口 Visitor,它包含了不同类型的具体元素的访问方法定义:
public interface Visitor {
void visitCircle(Circle circle);
void visitRectangle(Rectangle rectangle);
void visitTriangle(Triangle triangle);
}
定义了抽象元素和抽象访问者后,就可以定义具体的访问者类了。例如,一个画图访问者类,实现了抽象访问者接口中不同元素的操作方法:
public class DrawingVisitor implements Visitor {
public void visitCircle(Circle circle) {
// 画圆形
System.out.println(String.format("Draw Circle, x=%d, y=%d, r=%d",
circle.getX(), circle.getY(), circle.getRadius()));
}
public void visitRectangle(Rectangle rectangle) {
// 画矩形
System.out.println(String.format("Draw Rectangle, x=%d, y=%d, w=%d, h=%d",
rectangle.getX(), rectangle.getY(), rectangle.getWidth(), rectangle.getHeight()));
}
public void visitTriangle(Triangle triangle) {
// 画三角形
System.out.println(String.format("Draw Triangle, x1=%d, y1=%d, x2=%d, y2=%d, x3=%d, y3=%d",
triangle.getX1(), triangle.getY1(),
triangle.getX2(), triangle.getY2(),
triangle.getX3(), triangle.getY3()));
}
}
最后,定义客户端类对图形对象进行访问:
public class Client {
public static void main(String[] args) {
List<Shape> shapes = new ArrayList<>();
shapes.add(new Circle(10, 20, 5));
shapes.add(new Rectangle(30, 40, 50, 60));
shapes.add(new Triangle(70, 80, 90, 100, 110, 120));
Visitor visitor = new DrawingVisitor();
for (Shape shape : shapes) {
shape.accept(visitor);
}
}
}
其中,先创建了一个包含多种图形对象的列表 shapes,再创建一个画图访问者对象 drawingVisitor,最后遍历 shapes 列表中的所有图形对象,并使用 accept() 方法接受 drawingVisitor 的访问进行相应操作。
以上就是访问者模式在Java语言中的具体实现。通过参考这个例子,您可以更好地理解访问者模式的工作原理及其优缺点,同时也可根据需要对其进行进一步了解与应用。
好了,本篇文章就先分享到这里了,后续将会继续介绍23种设计模式之其他模式,感谢大佬认真读完支持咯~
文章到这里就结束了,如果有什么疑问的地方请指出,诸佬们一起讨论😁
希望能和诸佬们一起努力,今后我们顶峰相见🍻
再次感谢各位小伙伴儿们的支持🤞
开放原子开发者工作坊旨在鼓励更多人参与开源活动,与志同道合的开发者们相互交流开发经验、分享开发心得、获取前沿技术趋势。工作坊有多种形式的开发者活动,如meetup、训练营等,主打技术交流,干货满满,真诚地邀请各位开发者共同参与!
更多推荐
所有评论(0)