软件架构中的九种耦合形式

开发 架构
本文介绍了软件架构中的九种耦合形式,通过了解不同的层次的耦合,架构师和开发者在设计时就可以做出不同选择,从而实现针对性的设计。

没有任何软件系统可以摆脱依赖关系,或者保证即使依赖组件发生变化也不会产生任何影响。软件架构师总是要处理相互连接的组件之间的依赖程度,并尽量减少甚至消除这种影响。如果软件组件 A 在如下情况下需要软件组件 B,那么软件组件 A 就依赖于软件组件 B:

  • 运行时编译
  • 安装
  • 测试
  • 正常运行

耦合是任意架构构件之间的依赖程度。

在不同抽象层次上,存在着不同类型的耦合。耦合不仅发生在源代码层面,还发生在基础架构以及其他方面。软件架构师需要了解这些类型,以便在设计这些组件时做出正确决定。我们将根据 ISAQB 软件架构认证课程来了解这些耦合类型。

通过使用/委托耦合

这种耦合是经典耦合之一。基本上,如果类 A 调用类 B 的公有变量,它们就会通过使用/委托耦合在一起。最好的解决方法是将这些公有变量私有化,并通过 getter 调用它们。

通过组合耦合

在组合关系中,正如面向对象编程中所定义的,类 A 包含类 B。在某些情况下,类 B 可以是类 A 的内部部分,并不独立存在。因此,这些类通过组合关系耦合在一起。

通过构建耦合

这类耦合出现在工厂、抽象工厂等构建设计模式中。在这些设计模式中,类 A 或 B 的构建被委托给工厂类。也就是说,类 A 或 B 是通过构建与工厂类耦合的。

通过继承耦合

子类继承超类的属性和方法的一种依赖关系。通过继承产生的耦合非常严格,因为父类做什么,子类就做什么。

通过信息或事件耦合

消息传递中间件和事件存储广泛用于组件之间的松散耦合。在消息传递中,通信是异步的,发送方的请求被发送到消息队列中,接收方从队列中获取请求。发送方可能知道也可能不知道哪个接收方收到了请求,也不会立即回复。在事件处理中,想法与消息传递类似,但这里的状态变化是按时间顺序传递给监听者的。由于这种通信也是异步的,耦合非常松散,因此非常受欢迎。

时序耦合

在这种耦合中,如果 A 组件在 B 组件提供某些输出之前无法执行其工作,那么 A 组件就会暂时依赖于 B 组件。在这种耦合中,组件 A 和组件 B 不需要使用相同的编程语言或基础设施。例如,要在电商网站中购买一些商品,首先需要选择并将商品添加到购物车中。

通过数据类型耦合

根据业务需要,开发者会创建一些自定义数据类型以供进一步使用。例如,在 JPA 中创建的 UserEntity 与数据库中的 User 表相对应。因此,UserEntity 将成为软件系统中的核心数据类型,在任何需要处理用户数据的地方都可以使用。如果 UserEntity 有微小的变化,所有依赖类都会受到影响。这就是通过数据类型实现的耦合。

通过数据耦合

当组件 A 在数据库、配置文件或环境变量中持久化保存信息,而组件 B 也与之通信时,就会出现数据耦合。如果一个组件的变化通过这些耦合数据影响到另一个组件,那么很可能需要松开这些耦合。

通过硬件耦合

设想有一个物理硬件或服务器,组件 A 在内存位置写入了一些内容,组件 B 在读取这些内容时也会受到影响。这种耦合是通过硬件实现的,经常发生在底层编程中。

责任编辑:赵宁宁 来源: DeepNoMind
相关推荐

2020-04-10 20:32:44

网络安全黑客隐私

2018-12-28 09:00:00

2022-11-17 15:17:12

Java数据结构Map

2013-02-18 09:54:05

软件开发程序员

2018-07-13 09:38:54

2021-06-04 10:45:31

软件架构分布式

2020-06-28 10:15:39

架构模式软件

2017-09-14 09:30:38

软件架构模式

2010-10-11 10:31:51

MySQL分区

2023-12-01 07:24:40

软件架构

2010-07-05 09:37:19

ucd-snmpsnmpd扩展

2024-06-19 19:17:04

2024-10-17 16:01:02

2011-12-28 10:10:54

2013-09-30 10:12:44

Android DiaAndroid

2021-08-15 10:08:36

勒索软件恶意软件安全

2010-05-28 09:10:29

远程协助软件

2012-08-20 15:14:23

2020-10-09 06:52:31

设计模式软件

2024-05-07 08:23:03

Spring@Async配置
点赞
收藏

51CTO技术栈公众号