软件杂谈(1)- 解耦


-前言-

软件杂谈是大叔打算写的关于软件的随笔系列,多数是在开车行路中冒出的想法,又怕年纪大了忘却,便记下来。

有些人天生就喜欢写作或记录生活,这当然是个很好的习惯,而我却不太擅长。在我看来,静下心写一些东西是很奢侈的事情,每天奔波,很少能给自己挤出一点时间。

最近流行一句话:“贫穷限制了你的想象力”。忙碌又何尝不是?忙碌更像是鸦片,会使人习惯甚至麻木。你看,这世界上是不是中国人最勤劳忙碌,也恰巧是中国人最缺乏想象力,忙得没时间思考,没时间想象。

大叔很忙,可还有那么一个私密时间属于我独有,那便是开车的时候,安静且没人打扰。

这还要“感谢”我大西安的交通拥堵,别人抱怨,我却很享受。每天至少在车里度过两个小时,除了思考,还能做些什么?

当然,这种享受要对老司机来说才是这样,因为只有老司机才能腾出大脑,边开车边思考。

大叔搞软件技术20多年,驾龄15年,当然是老司机了(相信你没有想歪)。

言归正传,既是杂谈,便无有顺序可言,想到哪里聊到哪里。也无有题材限制,只要跟软件技术相关,都可以聊。

这一篇我们先聊一个词--“解耦”。

选解耦为关雎,还是有原因的,因为在大叔眼里,解耦太重要了。

重要到什么程度?基本上只要掌握好解耦,软件开发内功的任督二脉就基本打通了。

-概念-


解耦这个词译自英文decouple,翻译的非常好。

从词义上看:

解者,拆也,分也,离也,断也。

偶者,索也,合也,并也,缘也。

解耦,顾名思义就是降低软件体之间的耦合度,直至彻底断耦的过程。

我们这里所说的软件体,是指具有相对独立性的软件功能集合。可以理解为某个函数体或者模块,或更多的指可重用的服务和组件。

那么什么是耦合与耦合度呢?

所谓耦合,是指两个或多个软件体之间的依赖关系。耦合度就是这种相互依赖关系的强弱程度。

耦合度越高,软件体之间的牵连羁绊就越多,依赖性就越大,反之则反。

例如,一个组件,依赖于另一个组件才能够运行,那么就说这两个组件之间存在耦合。倘若一个组件依赖于它运行的环境才能够运行,那么就说这个组件跟环境之间存在耦合。

-思想由来-


解耦不是某种语言或者技术特有的概念,解耦是一种普遍存在的思想。

解耦的思想由来已久,早在软件可重用技术提出之前,硬件集成电路(IC)技术就普遍采取了解耦的技术。道理很简单,每一个集成电路模块在设计上必须具备独立性,标准性和解耦性,才能够像搭积木一样构建出复杂的系统。

伴随着软件可重用思想及相关技术的产生,接口和解耦的概念也应运而生。软件组件以及基于组件的开发(Component Based Development - CBD)要求组件能够像集成电路一样独立存在,通过事件松散耦合。由此发展出的一系列组件模型,都是解耦思想的完美实例。例如Enterprise JavaBeans (EJB)模型,Component Object Model (COM)模型,.NET模型等等。

在面向服务的架构(Service Orientation Architectures - SOA)中,也需要软件服务相互独立,没有耦合。

还有这些年流行的微服务,前后端分离,也是这样。

云计算以及云平台,也处处体现着解耦思想。例如,基础设施即服务 (IaaS)、平台即服务 (PaaS) 和软件即服务 (SaaS)等技术中都体现着热插拔,松耦合,资源动态分配整合的特点。

-耦合的影响-


软件体之间存在耦合,会增加软件实现的复杂度。

耦合像一种无形的力量,束缚着软件结构的健康。不经思考的随意耦合,可能造成内部逻辑混乱,难以纠正,有如三千烦恼丝,剪不断理还乱。

高耦合度的软件系统,阅读起来一定困难,维护成本一定提高,复杂度随之也高,也会导致质量的下降。

佛教思想中有十二因缘的理论,讲述由无明引起的环环相扣、因果相随的轮转生死过程。串接苦趣每一环节的是缘,要想获得自由、脱离生死,就要认识缘断了缘。

类似的,耦合的本质也是缘。而正是这种牵绊,造成系统复杂乃至生出种种问题和痛苦。

-解耦的本质-


既然耦合的本质是缘,那么解耦的本质就是断缘,并通过断缘提升软件体的自由。

没错,是自由!

自由会带来活力,自由会引发包容开放,自由会促进事物健康发展。

没想到这个充满人文思想的因素,在软件系统中也是这样。

一个国家缺少自由,必然会走向灭亡。一个软件系统缺少自由,必然会问题百出并导致失败。

原谅我这一生不羁放纵爱自由,大叔之所以把解耦放到第一篇来讲,也有这个原因,解耦太重要了,自由太重要了

-解耦的方法-


实际上,软件体之间不可能没有联系,否则我们靠什么把它们串接起来。

我们要拆解的不是依赖关系,而是要打破对某个具体实相的依赖,也就是对某个具体的软件体的真实性的依赖。这句话不拗口吧?

怎么打破?答案就是抽象和接口。

通过抽象和接口,依赖关系的实体消亡,软件体除了自身表现出内敛性外,一切对外的认知都建立在抽象和接口之上。

不着相,保持自性清净,是通达精神自由的方法。在解耦层面,亦复如是。

当软件体之间彻底断耦,它们中的每一部分就处于独立存在的状态。我们甚至可以把其中的任何一个替换掉,而不会影响整体正常工作。对整个系统而言,也带来了更大的自由度。

我们时常听到的依赖倒置,控制反转,依赖注入,面向接口编程这些概念,都是在抽象和接口依赖的关系上建立和实现的。

其实你可能每天都在接触解耦,只是自己也要用好解耦而已。

-解耦的人文精神-


一个耦合度小的软件设计和实现,无论从结构上还是细节上都会带给人赏心悦目的感觉。这种由内向外透出的美感,很大程度上就源于解耦后的软件体所具有的独立性和自由性。

而独立性和自由性,正是现代文明中的人类追求的精神价值和目标。

正如陈寅恪先生题写在《清华大学王观堂先生纪念碑铭》中的十个大字:“独立之精神 自由之思想”,时刻提醒着我们要在求知的道路上树立独立自由的精神。

作为软件工作者,想写出好的软件,也需要力求把这种独立自由的人文精神赋予在软件作品当中。

不自由,毋宁死。此时,解耦就显得尤为重要。

希望大家能够理解并应用好解耦,写出层次清晰,结构灵活,质量可靠,优美的软件。


-2018.03.31 蘭山 -




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

推荐阅读更多精彩内容