面向对象技巧之高内聚低耦合!!!

<h3>内聚</h3>
<p>当模块的元素全部专注于模块的职责的时候,即使元素间的结合不是很紧密,也符合内聚性的要求。简单的说,就是“<strong>不要挂羊头卖狗肉</strong>”。</p>
<ul>
<li>巧合内聚
</li>
</ul>
<blockquote>
<p>模块内部的元素被划分在一起,仅仅是因为“巧合”。</p>
</blockquote>
<ul>
<li>逻辑内聚</li>
</ul>
<blockquote>
<p>模块内部元素之所以被划分在一起,是因为这些元素逻辑上属于同一个比较宽泛的类别。</p>
<p>比如将鼠标、键盘划分入输入类,将打印机、显示器划分为输出类。</p>
</blockquote>
<ul>
<li>时序内聚</li>
</ul>
<blockquote>
<p>模块内部的元素之所以被划分在同一个模块中,是因为这些元素必须按照固定的“<strong>时间顺序</strong>”进行处理。</p>
</blockquote>
<ul>
<li>过程内聚</li>
</ul>
<blockquote>
<p>模块内部的元素之所以被划分在同一个模块中,是因为这些元素必须按照固定的“<strong>过程顺序</strong>”进行处理。</p>
<p>判断文件是否存在、判断文件是否有权限、打开文件、读(或者写)文件,那么把这些处理封装在一个函数中,它们之间的内聚就是“过程内聚”。</p>
</blockquote>
<ul>
<li>交互内聚</li>
</ul>
<blockquote>
<p>模块内部的元素之所以被划分在同一模块中,是因为这些元素都操作相同的数据。</p>
<p>交互内聚最常见的就是数据结构的类定义了,例如 Java HashMap 的 get、put、clear 等操作。</p>
</blockquote>
<ul>
<li>功能内聚</li>
</ul>
<blockquote>
<p>模块内部的元素之所以被划分在同一模块中,是因为这些元素都是为了完成同一项任务。</p>
</blockquote>
<h3>耦合</h3>
<blockquote>
<p><strong>耦合和内聚是相反的:内聚关注模块内部的元素结合程度,耦合关注模块之间的依赖程度。</strong></p>
</blockquote>
<ul>
<li>无耦合</li>
</ul>
<blockquote>
<p>无耦合意味着模块之间没有任何关系或者交互。</p>
</blockquote>
<ul>
<li>消息耦合</li>
</ul>
<blockquote>
<p>系统/子系统:两个系统交互的协议数据,例如:HTTP POST 数据,Java RPC、Socket 数据等;
类/函数:函数的参数即“消息”。例如:A 类的函数调用了 B 类的某个函数,传入的参数就是消息。</p>
</blockquote>
<ul>
<li>数据耦合</li>
</ul>
<blockquote>
<p>两个模块间通过参数传递基本数据,称为数据耦合。</p>
</blockquote>
<ul>
<li>数据结构耦合</li>
</ul>
<blockquote>
<p>数据结构耦合和数据耦合是比较相近的,主要差别在于数据结构耦合中传递的不是基本数据,而是数据结
构数据。</p>
</blockquote>
<ul>
<li>控制耦合</li>
</ul>
<blockquote>
<p>当一个模块可以通过某种方式来控制另外一个模块的行为时,称为控制耦合。</p>
</blockquote>
<ul>
<li>外部耦合</li>
</ul>
<blockquote>
<p>为了让香港的插头也能在大陆用,我们就需要买一个“电源转换头”,其作用就是能够让原来不兼容的香港插头和大陆插座两个设备能够连接起来,但原有两个设备内部都继续保持原样。</p>
<p>这里的香港插头和大陆插座就是外部耦合关系,外部设备是“电源转换头”
在软件系统,外部依赖最典型的莫过于各种“proxy”模块或者子系统了。比如说 A 系统输出 XML 格式,
B 系统只能接收 JSON 格式的数据,为了能够让两个系统连接起来,需要开发一个转换程序,完成格式转换。</p>
<p>简单来说,很多东西不是你想改就能改的!使用外部依赖一般的主要原因如下:</p>
<ol>
<li>已有系统无法改动:比如说你买的香港插头和大陆插座,除非你真的是吃饱了没事做或者要挑战自己,否则一般人都不会自己动手将香港插头改为大陆插头,或者将大陆插座改为香港插座。</li>
<li>已有系统已经成熟,改动需要很高的成本,也会导致系统不稳定。</li>
<li>已有系统支持很多其它系统,不能为了你的系统单独修改。</li>
</ol>
</blockquote>
<h3>高内聚低耦合</h3>
<blockquote>
<p><strong>如果我们不做到这点,将会怎样?</strong></p>
</blockquote>
<p><em>如果一个模块内聚性较低,则这个模块很容易变化。一旦变化,设计、编码、测试、编译、部署的工作量就上来了,而一旦一个模块变化,与之相关的模块都需要跟着改变。</em></p>
<blockquote>
<p><strong>高内聚低耦合是否意味着内聚越高越好,耦合越低越好?</strong></p>
</blockquote>
<ol>
<li>
<p>并不是内聚越高越好,耦合越低越好,真正好的设计
是在高内聚和低耦合间进行平衡,也就是说高内聚和低耦合是冲突的。</p>
</li>
<li>
<p>最强的内聚莫过于一个类只写一个函数,这样内聚性绝对是最高的。但这会带来一个明显
的问题:类的数量急剧增多,这样就导致了其它类的耦合特别多,于是整个设计就变成了“高内聚高耦合”了。由于高耦合,整个系统变动同样非常频繁。</p>
</li>
<li>
<p>对于耦合来说,最弱的耦合是一个类将所有的函数都包含了,这样类完全不依赖其它类,耦合性是最低的。但这样会带来一个明显的问题:内聚性很低,于是整个设计就变成了“低耦合低内聚”了。由于低内聚,整个类的变动同样非常频繁。</p>
</li>
<li>
<p>对于“低耦合低内聚”来说,还有另外一个明显的问题:几乎无法被其它类重用。原因很简单,类本身太庞大了,要么实现很复杂,要么数据很大,其它类无法明确该如何重用这个类。</p></li></ol>

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 202,802评论 5 476
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,109评论 2 379
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 149,683评论 0 335
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,458评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,452评论 5 364
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,505评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,901评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,550评论 0 256
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,763评论 1 296
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,556评论 2 319
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,629评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,330评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,898评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,897评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,140评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 42,807评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,339评论 2 342

推荐阅读更多精彩内容