Java学习之浅析高内聚低耦合
•前言
如果你涉及软件开发,可能会经常听到 “高内聚,低耦合” 这种概念型词语。
可是,何为 “高内聚,低耦合” 呢?
•概念
“高内聚,低耦合” 是相对于代码而言,一个项目中:
- 每个模块之间相互联系的紧密程度,模块之间联系越紧密,则耦合性越高,模块的独立性就越差,反之同理;
- 一个模块中各个元素之间的联系的紧密程度,如果各个元素(语句、程序段)之间的联系程度越高,则内聚性越高,即 “高内聚” ;
如:一个项目中有20个方法调用良好,但是要修改了其中一个,另外的19个都要进行修改,这就是高耦合,独立性太差;
现在的软件结构设计,都会要求 “高内聚,低耦合”,来保证软件的高质量!
•通过代码直观感受
假设有一个数组 a[] = {1,2,3,4,5} ;
现在需要你通过代码计算公式
$(a[0]+a[1]+\cdots+a[4])\cdot(a[0]+a[1]+\cdots+a[3])\cdot_{\cdots}\cdot a[0]$
的值,你可以这么编写代码:
static int[] a = new int[] {1,2,3,4,5}; public static void main(String[] args) { //计算a[0]+a[1]+a[2]+a[3]+a[4]
int sum1 = 0;
for(int i = 0;i <= 4;i++) {
sum1 += a[i];
} //计算a[0]+a[1]+a[2]+a[3]
int sum2 = 0;
for(int i = 0;i <= 3;i++) {
sum2 += a[i];
} //计算a[0]+a[1]+a[2]
int sum3 = 0;
for(int i = 0;i <= 2;i++) {
sum3 += a[i];
} //计算a[0]+a[1]
int sum4 = 0;
for(int i = 0;i <= 1;i++) {
sum4 += a[i];
} //计算a[0]
int sum5 = 0;
for(int i = 0;i <= 0;i++) {
sum5 += a[i];
} //计算乘积
int sum = sum1*sum2*sum3*sum4*sum5;
System.out.println(sum);
} }通过分析代码你会发现:重复代码太多!
如果我们把重复的代码提取出来,会怎么样呢?
稍加修改一下:
public class SimpleDemo { static int[] a = new int[] {1,2,3,4,5}; public static void main(String[] args) { //计算a[0]+a[1]+a[2]+a[3]+a[4]
int sum1 = Sum(0, 4); //计算a[0]+a[1]+a[2]+a[3]
int sum2 = Sum(0, 3); //计算a[0]+a[1]+a[2]
int sum3 = Sum(0, 2); //计算a[0]+a[1]
int sum4 = Sum(0, 1); //计算a[0]
int sum5 = Sum(0, 0); //计算乘积
int sum = sum1*sum2*sum3*sum4*sum5;
System.out.println(sum);
} public static int Sum(int x,int y) {
int sum = 0;
for(int i = x;i <= y;i++) {
sum += a[i];
}
return sum;
}
}通过代码的复用,我们将大部分冗余代码进行了清理。
•小结
讲了这么多,你大概猜到耦合是什么意思了:
- 将一串代码模块化(即封装为不同方法),每个模块(方法)都有自己的功能
- 封装方法越多,耦合度越低
- 模块与模块之间接口的复杂程度,模块之间联系越复杂,耦合度越高
那么内聚就是:
- 每个模块(方法)相互分离的情况下,修改了某模块(方法)其中的某些代码,但并不影响和其它模块的通讯(即高内聚)
- 每个模块尽可能独立完成自己的功能,不依赖于模块外部的代码。
•声明
参考资料
Java学习之浅析高内聚低耦合的更多相关文章
- Java编码思想之什么是高内聚低耦合?
分别描述的是模块内部特征,和模块外部引用关系. 内聚就是一个模块内各个元素彼此结合的紧密程度,高内聚就是一个模块内各个元素彼此结合的紧密程度高. 内聚是就其中任何一个模块的内部特征而言的. 耦合是就多 ...
- 面系那个对象开发原则.高内聚.低耦合+Python安装详细教程+print输出带颜色的方法
面系那个对象开发原则.高内聚.低耦合 软件设计中通常用耦合度和内聚度作为衡量模块独立程度的标准.划分摸块的一个准则就是高内聚低耦合. 这是软件工程中的概念,是判断设计好坏的标准,主要是面向OO的设计, ...
- Office之什么是高内聚低耦合
---恢复内容开始--- 高内聚低耦合,是软件工程中的概念,是判断设计好坏的标准,主要是面向对象的设计,主要是看类的内聚性是否高,耦合度是否低. 粗劣的说就指的是:单独模块间有着强大的凝聚力,不同的模 ...
- 如何设计一个高内聚低耦合的模块——MegEngine 中自定义 Op 系统的实践经验
作者:褚超群 | 旷视科技 MegEngine 架构师 背景介绍 在算法研究的过程中,算法同学们可能经常会尝试定义各种新的神经网络层(neural network layer),比如 Layer No ...
- 对C++中高内聚,低耦合原则的理解
1.C语言是面向过程的语言,采用模块化的设计思想,每个功能划分为一个模块,是以函数为单位的. 2.C++是面向对象的语言,采用类设计的思想,因此C++中的模块是以类为基本单位的. 高内聚,低耦合能够使 ...
- Python学习第十八篇——低耦合函数设计思想
import json 2 def greet_user(filename): 3 try: 4 with open(filename) as f_obj: 5 username = json.loa ...
- 高灵活低耦合Adapter快速开发攻略
Android开发中经常需要使用Adapter. 传统方法是自定义一个Adapter并继承AndroidSDK内的BaseAdapter, 这种方式代码量大,耦合度高,灵活性差(各种监听事件需要对Vi ...
- [ Java学习基础 ] 浅析Java方法调用
先看一个示例,读者可先自行阅读判断输出结果: public class TestClass { private static void testMethod(){ System.out.printl ...
- Java学习---面试基础知识点总结
Java中sleep和wait的区别 ① 这两个方法来自不同的类分别是,sleep来自Thread类,和wait来自Object类. sleep是Thread的静态类方法,谁调用的谁去睡觉,即使在a线 ...
随机推荐
- rename github
rename GitHub github repo rename xgqfrms 2012-2020 www.cnblogs.com 发布文章使用:只允许注册用户才可以访问!
- cnblogs & 502 Bad Gateway
cnblogs & 502 Bad Gateway 博客园 502 Bad Gateway 服务器发生了一些错误,请联系 contact@cnblogs.com 可以查看,不可以编辑 HTTP ...
- Dart & import show & import hide & import as & part & part of
Dart & import show & import hide & import as & part & part of // 部分导入,即仅仅导入 dart ...
- 2020 front-end interview
2020 front-end interview https://juejin.im/post/5e083e17f265da33997a4561 xgqfrms 2012-2020 www.cnblo ...
- 「NGK每日快讯」2021.1.25日NGK公链第83期官方快讯!
- MySQL修改表中字段的字符集
MySQL修改表中字段的字符集 ALTER TABLE 表名 MODIFY 字段名 要修改的属性: 例:ALTER TABLE `guaduates` MODIFY `studentno` CHAR( ...
- 怎么创建CSV文件和怎么打开CSV文件
CSV(Comma Separated Values逗号分隔值). .csv是一种文件格式(如.txt..doc等),也可理解.csv文件就是一种特殊格式的纯文本文件.即是一组字符序列,字符之间已英文 ...
- KMP算法,你想知道的都在这里!
简洁 我相信很多人都听说过KMP算法(PS:在上数据结构的时候,这个算法自始至终都没想明白) 大家也知道KMP算法是用来寻找目标子串的算法,但是都没有真正搞懂KMP.之前,我也是如此,我疑惑的有: N ...
- TERSUS无代码开发(笔记05)-简单实例电脑端页面设计
案例笔记电脑端页面设计 1.新建项目(请假管理qjgl) 2.开发软件界面介绍(常用的功能按键) 3.目录中显示元件对象 4.对元件对象的操作主要方式是双击(双击哪个元件, ...
- JS把数组元素分组
有一个数组,把其中的元素按照每5个进行重新分组,新的数组放到放到大数组中,且看代码 let data = [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, ...