我理解这种低耦合高内聚的说法有问题。我在谷歌上搜索并阅读了很多这方面的内容,但还是觉得很难理解。

我的理解是,高内聚意味着,我们应该有专门执行特定功能的类。希望这是正确的?比如信用卡验证类,它专门用于验证信用卡。

还是不明白低耦合是什么意思?


当前回答

我想你们已经有了很多定义,但如果你们仍然有疑问,或者如果你们是编程新手,想深入了解这个问题,那么我建议你们看这个视频, https://youtu.be/HpJTGW9AwX0 这只是一个参考,以获得更多关于多态性的信息… 希望你能更好地理解这一点

其他回答

我想你们已经有了很多定义,但如果你们仍然有疑问,或者如果你们是编程新手,想深入了解这个问题,那么我建议你们看这个视频, https://youtu.be/HpJTGW9AwX0 这只是一个参考,以获得更多关于多态性的信息… 希望你能更好地理解这一点

低耦合和高内聚是一个值得推荐的现象。

耦合意味着各个模块相互依赖的程度,以及其他模块在改变模块的某些/相当大的功能时是如何受到影响的。低耦合被强调,因为依赖关系必须保持在较低的水平,以便对其他模块进行非常少的/可以忽略不计的更改。

继承或泛化是高耦合(即高度相互依赖)的一个例子。我这么说的意思是,在继承中,父类通常定义了它的子类使用的基本功能,父类方法的更改直接影响它的子类。因此,我们可以说,阶级之间有更大程度的相互依赖。

实现或使用接口是一个高内聚(即低相互依赖)的例子。这意味着接口为实现它的任何类提出了契约,但每个类都有权以自己的方式实现接口中声明的方法,并且一个类中声明的方法的更改不会影响任何其他类。

低耦合:—— 让它变得简单。 如果你改变了你的模块,它对其他模块有什么影响?

例子:- 如果您的服务API公开为JAR,对方法签名的任何更改都将破坏调用API(高/紧耦合)。

如果您的模块和其他模块通过异步消息通信。只要您获得消息,您的方法更改签名将是您模块的本地(低耦合)。

如果消息格式发生变化,则呼叫客户端将需要进行一些更改。

你有智能手机吗?有一个大的还是很多小的应用程序?一个应用程序是否会回复另一个应用程序?您可以在安装、更新和/或卸载另一个应用程序时使用一个应用程序吗?每个应用程序都是独立的,这是一种高内聚性。每个应用程序都独立于其他应用程序,这是低耦合。DevOps偏爱这种架构,因为这意味着您可以在不中断整个系统的情况下进行离散的连续部署。