2分钟彻底搞懂“高内聚,低耦合”

这篇具有很好参考价值的文章主要介绍了2分钟彻底搞懂“高内聚,低耦合”。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

💗推荐阅读文章💗

  • 🌸JavaSE系列🌸👉1️⃣《JavaSE系列教程》
  • 🌺MySQL系列🌺👉2️⃣《MySQL系列教程》
  • 🍀JavaWeb系列🍀👉3️⃣《JavaWeb系列教程》
  • 🌻SSM框架系列🌻👉4️⃣《SSM框架系列教程》

🎉本博客知识点收录于🎉👉🚀《SSM框架系列教程》🚀—>✈️01【高内聚低耦合、Spring概述、IOC容器、Bean的配置方式】✈️

一、高内聚低耦合

1.1 程序架构设计

高内聚低耦合,是软件工程中的概念,是判断软件设计好坏的标准,主要用于程序的面向对象的设计,主要看类的内聚性是否高,耦合度是否低。目的是使程序模块的可重用性、移植性大大增强。通常程序结构中各模块的内聚程度越高,模块间的耦合程度就越低

  • 内聚是从功能角度来度量模块内的联系,一个好的内聚模块应当恰好做一件事,它描述的是模块内的功能联系;

  • 耦合是软件结构中各模块之间相互连接的一种度量,耦合强弱取决于模块间接口的复杂程度、进入或访问一个模块的点以及通过接口的数据。

Tips:元素可以是方法、对象(类),也可以指系统、子系统、模块、服务等。

  • 1)高内聚低耦合是软件架构的一种概念、思想;
  • 2)内聚与耦合想相对的,内聚程度越高那么耦合度就低,内聚程度越低往往耦合度就高;
  • 3)我们在软件设计时,应该尽量做到高内聚、低耦合;

1.2 低耦合

1.2.1 耦合概念

耦合,简单的来说就是元素(类)与元素(类)之间的关系;我们在设计程序时应该降低元素与元素之间的直接关系;降低元素与元素之间的耦合性;

假如一个元素A去调用元素B,或者通过自己的方法可以感知B,当B不存在的时候就不能正常工作,那么就说元素A与元素B耦合。耦合带来的问题是,当元素B发生变更或不存在时,都将影响元素A的正常工作,影响系统的可维护性和易变更性。同时元素A只能工作于元素B存在的环境中,这也降低了元素A的可复用性。

1.2.2 如何降低耦合

简单的来说就是元素A不能过度依赖元素B;

  • 1)定制合理的职责划分,让系统中的对象各司其职,不仅是提高内聚的要求,同时也可以有效地降低耦合;

  • 2)使用接口而不是继承:我们不难发现。继承就是一种耦合,假如子类A继承了父类B,父类B修改了任何功能将直接影响到子类,而接口则是将功能延迟到了子类中来实现;

1.3 高内聚

架构设计时的内聚高低是指,设计某个模块时,模块内部的一系列相关功能的相关程度的高低。相关程度越高,我们称之为高内聚,反之低内聚;内聚是从功能角度来度量模块内的联系,一个好的内聚模块应当恰好做一件事。它描述的是模块内的功能联系。

很明显,程序的内聚性越高,代表功能的相关性也就越高,从一定程度上来说,这个功能就应该属性这个元素;因此耦合性就降低了;

程序讲究的是低耦合,高内聚。就是同一个模块内的各个元素之间要高度紧密,但是各个模块之间的相互依存度却要不那么紧密。

1.4 不能完全低耦合

高内聚低耦合只是一个度的问题,我们并不能做到完全的高内聚低耦合;有时候太过严格反而会适得其反

我们可以举几个代码上的例子:

1)我们的UserServlet中,出现了UserService和DeptService,从一定程度上来讲,Dept的业务应该是不属于我User管辖的

高内聚低耦合什么意思,Java,Spring,软件设计,高内聚,低耦合,软件工程

如果要严格按照"高内聚,低耦合"的要求来,那么只能把DeptService的业务写在DeptServlet中,这样做虽然是降低了UserServlet与DeptService的联系,提高了UserServlet的内聚,但很显然,UserService变得非常臃肿(高耦合、低内聚)

2)我们再"严格"一点,ArticleServlet的功能应该由ArticleServlet来提供,而不需要借助其他类,否则ArticleServlet就与ArticleService产生耦合关系:

高内聚低耦合什么意思,Java,Spring,软件设计,高内聚,低耦合,软件工程

那么为了进一步降低耦合性,只能把ArticleService的代码编写到ArticleServlet中,那么很显然,ArticleSerlvet的内聚性就非常低了,因为很多不是属于ArticleServlet的代码也编写到ArticleServlet中了;

因此"高内聚低耦合只是一个度的问题",但是实际的设计开发过程中,总会发生这样那样的问题与情况,真正做到高内聚、低耦合是很难的,很多时候未必一定要这样, 更多的时候“最适合”的才是最好的, 不过,理解思想,审时度势地使用, 融会贯通,灵活运用,才是设计的王道。

比如说我们设计一个类可以不与JDK耦合,这可能吗?除非你不是设计的Java程序。再比如我设计了一个类,它不与我的系统中的任何类发生耦合。如果有这样一个类,那么它必然是低内聚,而且是非常低的内聚(因为所有的功能都在一个类的,耦合非常高,内聚非常低)。耦合与内聚常常是一个矛盾的两个方面。最佳的方案就是寻找一个合适的中间点。

  • 高内聚:一个的元素中的功能应该都是相关程度非常高的,不要提供与本身无关的功能

  • 低耦合:尽量与其他元素不要产生关系;文章来源地址https://www.toymoban.com/news/detail-842611.html

到了这里,关于2分钟彻底搞懂“高内聚,低耦合”的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 花一分钟彻底搞懂Mac输入法/中英文/大小写切换

    最近有麦友说:没搞懂 Mac 怎么切换输入法、中英文和大小写,比如以前点按大写锁定键就可以切换到大写,现在要长按。有的时候点按大写锁定键或 shift 键都可以切换中英文,有的时候又不行。切换的时候基本就是碰运气瞎按。 之所以会有这种感觉,可能是因为以下几点:

    2024年02月07日
    浏览(42)
  • 【Spring框架】一篇文章带你彻底搞懂Spring解决循环依赖的底层原理

    目录 一、前言 二、什么是循环依赖 三、Spring Bean 的循环依赖问题 3.1 Bean 的创建步骤 3.2 为什么 Spring Bean 会产生循环依赖问题? 3.3 什么情况下循环依赖可以被处理? 四、Spring 如何解决循环依赖问题? 4.0 什么是三级缓存 4.1 简单的循环依赖(没有AOP) 4.1.0 创建Bean的前期流

    2024年04月17日
    浏览(42)
  • 一篇文章让你搞懂TypeScript中的typeof()、keyof()是什么意思

    知识专栏 专栏链接 TypeScript知识专栏 https://blog.csdn.net/xsl_hr/category_12030346.html?spm=1001.2014.3001.5482 有关TypeScript的相关知识可以前往TypeScript知识专栏查看复习!! 最近在 前端的深入学习过程 中,接触了与 网络请求 相关的内容,于是计划用三个专栏( HTTP 、 Axios 、 Ajax )和零碎

    2023年04月21日
    浏览(42)
  • Vue最新状态管理工具Pinia——彻底搞懂Pinia是什么

    知识专栏 专栏链接 Vuex知识专栏 https://blog.csdn.net/xsl_hr/category_12158336.html?spm=1001.2014.3001.5482 Vuex官方文档 https://vuex.vuejs.org/zh/ Pinia官方文档 https://pinia.web3doc.top/ 最近在 前端的深入学习过程 中,接触了与 状态管理 相关的内容,涉及到 与vue2适配的vuex 和 与vue3适配的pinia ,因此

    2024年02月03日
    浏览(35)
  • 一文彻底搞懂为什么OpenCV用GPU/cuda跑得比用CPU慢?

    最近项目需要,发现了这个问题。网上找原因,汇总起来,有以下几点原因: 1、首先对于任何一个CUDA程序,在调用它的第一个CUDA API时后都要花费秒级的时间去初始化运行环境,后续还要分配显存,传输数据,启动内核,每一样都有延迟。这样如果你一个任务CPU运算都仅要

    2024年02月03日
    浏览(38)
  • 【科普】1分钟帮你搞懂机械硬盘、固态硬盘、内存、cpu是什么?如何挑选?

    当你使用电脑时,机械硬盘、固态硬盘、内存和CPU都是非常重要的组件。以下是它们的基本定义和作用: 机械硬盘(HDD) 机械硬盘是计算机中的一种数据存储设备,它使用旋转的盘片和移动的磁头来读写数据。机械硬盘通常比固态硬盘容量更大,价格更便宜,但是速度相对

    2024年02月09日
    浏览(32)
  • [Java SE] 彻底搞懂Java程序的三大参数配置途径:系统变量与JVM参数(VM Option)/环境变量/启动程序参数args

    一次没搞懂,处处受影响。这个问题属于基础问题,但又经常踩坑,不得不重视一下了。 IDEA中的配置位置 参数 使用方式 示例 代码获取方式 系统属性 由操作系统、JVM、应用程序主动设置 System.setProperties(Properties propes) / System.setProperties(String key,String value) / System.getProperties(

    2024年02月08日
    浏览(34)
  • Java双冒号::是什么意思

    双冒号“::”就是 Java 中的方法引用,是Java 8中的Lambda表达式写法之一,一种执行方法的方法。 在一定程度上 简化了我们Java开发的冗余代码 。 双冒号(::)使用场景一般有如下6种 例如:

    2024年02月14日
    浏览(37)
  • Java的||或者&&是什么意思?

    1.|| a||b 短路或 ab 全为 false 时,计算结果为 false,否则为 true。 21||34 false 具体解释就是:||表示或,只要有一个为true,结果就为true,两个为false结果才为false 2. ab 短路与 ab 全为 true 时,计算结果为 true,否则为 false。 2134 true 具体解释就是:表示与,只要有一个为false,结果

    2024年02月11日
    浏览(35)
  • Spring Data Redis + RabbitMQ - 基于 string + hash 实现缓存,计数(高内聚)

    目录 一、Spring Data Redis 1.1、缓存功能(分析) 1.2、案例实现 hash 类型存储缓存相比于 string 类型就有更多的更合适的使用场景. 例如,我有以下这样一个 UserInfo 信息  假设这样一个场景就是:

    2024年02月05日
    浏览(32)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包