java - 业务逻辑类中的抽象

标签 java class-design cohesion

当您从库中调用方法时,您希望它完全按照其名称所暗示的那样执行操作。

Connection c = driver.getConnection();
  1. 返回连接
  2. 如果失败则报告错误
  3. 不要做超出预期的事情

编写“库代码”时,很容易坚持解耦、内聚、抽象原则。大多数时候,不遵守这些规定意味着设计上的错误。

但是当你在业务逻辑中时,就会出现一些困难,也许必须改变视角。在业务逻辑层面我说:

session.connect(); //session is of Session type, my "business logic class"

我希望它读取配置文件,如果找不到它,则采用默认值,连接,进行一些检查,决定需要向用户通知哪个警告,例如数据库版本较旧的事实比客户端软件。

如果你说一个方法不应该做所有这些事情,因为它必须具有内聚性,并且严格应用这一点,你最终会得到一个只有一行的 connect 方法:

 public class Session {
        ...
        Connection c;
        public void connect() {
             c = driver.getConnection();
        }      
 }

即业务类Session的方法connect会折叠到底层类。

剩下的任务呢?读取文件,检查数据库版本等?

您将业务代码推迟到将执行所有逻辑的“大方法”。

这正是我的观点。

如果您在业务逻辑上下文中应用内聚和解耦原则,您将无法将任务分割为更小的子任务,并且您将有一些大的“整体”方法来完成所有工作并且可读性很差。

我发现低级库 (Driver.getConnection()) 的良好原则(内聚、抽象)对于业务逻辑来说相当不够。

我的想法是:

  1. 必须用全新的概念取代凝聚力
  2. 内聚力必须“拉伸(stretch)”到一定程度

由于我更喜欢​​第二个,所以我的问题是那一点是什么。

最佳答案

我认为您缺少 OOP 概念和良好设计中的一些部分。如果你的代码不再可读 - 正如 Martin Fowler 提到的那样,如果你的代码有异味 - 因为你试图增加内聚性或减少耦合(你无法消除与 %0 的耦合,或者无法将内聚性提高到 100%。当您尝试此操作时,您会得到类似于上面的 connect() 示例的代码),您走错了路。因为,这些概念是为了让你的代码更具可读性。还有诸如“提取方法”之类的重构概念来增加内聚性。内聚和耦合通常与形容词一起使用,“低耦合”和“高内聚”。它们必须有多低或多高,设计师必须决定/优化它。顺便说一句,如果您调用 session.connect() ,我不认为必须配置连接。为此,还有许多其他概念,如连接工厂、 session 管理器和 Co。如果连接一旦配置,那么您可以调用 connect() 方法来建立与设备(数据库)的物理连接。

关于java - 业务逻辑类中的抽象,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6170720/

相关文章:

java - 使用泛型多个边界的未经检查/未经确认的强制转换

java - 通过 Java 程序连接列和运行查询时使用别名

java - 类设计 - 手动类型转换替代方案

Java - 从通用方法返回正确的类型

php - 是否值得尝试为世界上最紧密耦合的站点编写测试?

java - 尝试在 android 中实现滑动 View 时出错

java - 在 Thymeleaf 中根据特定条件使图像可点击

java - 有没有比几个 if 语句更有效的方法来处理按钮点击事件?

java - 提高类的内聚和耦合

c - 开源还是免费软件 C 代码度量工具?