访客设计模式和观察者设计模式可以结合吗?

问题描述

我说我有一个简单的Java程序,该程序读取一些文件显示一些数据。

我很困惑,我认为应该采用一种模式,但是我不能决定要实施哪种模式。

这是场景

每当我选择一个目录时,我都希望我的程序显示该目录名,所有文件列表和其他数据(如文件大小,文件扩展名等)。每当我单击一个文件名时,我都希望我的程序以显示其路径,如果它是图像文件和其他内容,则进行预览。

程序将数据保留在 dataHolder 类中:文件selectedDirectory,列表文件InthatDirectory,文件selectedFile,JSONObject fileData等...

该程序将具有许多 GUI对象显示;文本字段,面板,标签,列表。

经典的旧方法是用一个方法编写所有代码*按一下ActionListener内的按钮-> *从磁盘上获取文件,*读取它们的名称和其他内容,*用数据填充GUI对象。这有点不好。

所以我决定使用设计模式。然后,每当我单击此按钮并从磁盘读取时,我只会更新 dataHolder类(setSelectedDirectory,setFileData,fillCurrentFilesList ..这样的方法),而这些更新操作将触发 >类将进行所需的GUI更新。

但是我停留在两种方法之间;

-使用观察者模式,我创建了一些观察者,例如,当dataHolder的fileData(JSON)对象更新时,我会通知相关的textField,然后它们将显示正确的数据。

-但使用 Visitor模式,访问者类将处理不同的对象,它将为不同的GUI类运行不同的代码。 JList将尝试显示列表,或者某些textFields将尝试解析JSONObject并仅显示相关的String。但是我不需要太多不同的功能,我的意思是我只希望GUI对象显示一些数据,我唯一的访问者类是displayVisitor,它将期望GUI显示对象的唯一工作-显示数据。如果我需要doSomethingVisitor,doAnotherThingVisitor,doAmazingThingVisitor ...这种方法很好,但我不需要其他功能

这两种方法都能达到目的吗?我只是无法获得这种情况的区别。两者都提供了解决方案,Observer更简单,但是它是否提供处理不同的GUI类,例如用Arraylist填充JList或制作显示jpeg文件的JLabel?

或者我可以结合使用这些模式吗?感谢您的阅读。

解决方法

我想说,观察者模式更适合您的情况。访客模式适用于要向某些不想修改的对象添加功能的场景。