gpt4 book ai didi

java - N 层发布/订阅者设计问题

转载 作者:行者123 更新时间:2023-12-01 05:55:25 24 4
gpt4 key购买 nike

我刚刚开始研究如何编写优秀软件的优秀架构系统,我正在学习如何将高级组件分成层。在这种情况下,我尝试使用层,以便将每个层建模为黑色框。

我的架构中有 4 层:演示、应用程序服务、业务逻辑和域/持久性。出于我的问题的目的,我们实际上只需要关注表示和应用程序服务。

应用程序服务层将包含允许跟踪的服务某个事件的。演示文稿将有几个观点,应随着事件跟踪模型的变化而动态更新。本质上,看来我需要一种单向变更传播机制。

由于我尝试将这些层建模为层,因此我想限制通信每个 Tier 的 Facade 对象之间,并在必要时允许一个 Tier聚合来自较低一层的对象,尽管仅通过接口(interface)知道。

我正在用 Java 编写这个应用程序,所以显而易见的是要使用的是可观察/观察者。但是,我不喜欢的更新方法观察者接口(interface)强制您转换对象参数。我想解决这是通过为此机制定义我自己的接口(interface)和类来实现的。问题,那么,应用程序逻辑将依赖于演示文稿中的接口(interface)Tier,对于这个架构来说是一个禁忌。这是我应该尝试的迹象吗使用 MVC 进行建模并分层模型?或者这是一个更好的主意使用应用程序服务层中已知的接口(interface)对每个 View 进行建模。这似乎是一个不好的地方,我被困住了。另外,我使用 View 处理程序设计模式来处理多个 View 。

最佳答案

Observer/Observable 通常不是最好的方法,特别是在 Java 中,您必须从 Observable 派生,从而浪费了单一继承。正如您所讨论的,它还会导致耦合,这在跨层时会很糟糕。

我更倾向于研究纯事件模型,其中的服务提供了一种注册 EventListener 的方法,并在更改发生时触发 PropertyChangeEvent。

然后,服务层可以通知其他服务,或者通知表示层——它不知道也不关心,只有表示层通过注册为监听器的方式耦合到服务。

关于java - N 层发布/订阅者设计问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3198145/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com