自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

用Unix的設(shè)計思想來應(yīng)對多變的需求

系統(tǒng) Linux
我曾經(jīng)在《Unix傳奇》的下篇中寫過一些Unix的設(shè)計哲學(xué)和思想(這里重點推薦大家看一下《The Art of Unix Programming》,我推薦過多次了),以前也發(fā)過一篇“一些軟件設(shè)計的原則”,不過,這些東西都太多了,記不住。

之前,@風(fēng)楓峰 在“這是誰的錯?”中說過開發(fā)團(tuán)隊對需求來者不拒,而@weidagang 也在“需求變更和IoC” 中說過用IoC來最大程度地解決需求變更。今天我也想從Unix設(shè)計思想的角度來說說什么是好的軟件設(shè)計,什么樣的設(shè)計可以把需求變更對開發(fā)的影響降低。(注意:這并不能解決用戶或是PM的無理需求,面對無理需求,需要仔細(xì)分析需求,而用技術(shù)的手段無法搞定這個事,但是可以減輕需求變更帶來的痛苦)

我曾經(jīng)在《Unix傳奇》的下篇中寫過一些Unix的設(shè)計哲學(xué)和思想(這里重點推薦大家看一下《The Art of Unix Programming》,我推薦過多次了),以前也發(fā)過一篇“一些軟件設(shè)計的原則”,不過,這些東西都太多了,記不住。其實,這么多年來,我的經(jīng)驗告訴我,無論是Unix設(shè)計,還是面向?qū)ο笤O(shè)計,還是別的什么如SOA,ECB,消息,事件,MVC,網(wǎng)絡(luò)七層模型,數(shù)據(jù)庫設(shè)計,等等,他們都在干三件事——解耦,解耦,還是解耦!所謂解耦,就是讓程序員的模塊和模塊間盡量少地依賴起來。

 

[[69617]]

 

現(xiàn)實當(dāng)中的例子

讓我先舉幾個現(xiàn)實生活中的例子:

1、現(xiàn)實社會中,制造燈具的工廠完全不關(guān)心制造燈飾的工廠,制造燈飾的工廠完全不關(guān)心制造燈具的工廠,但是,燈具和燈飾可以很完美地組合成用記所喜歡的樣子(這和@weidagang 在“需求變更和IoC”說到的那個PC的例子相仿)。他們是怎么做到的?

2、互聯(lián)網(wǎng)上,做網(wǎng)站的人完全不用關(guān)心用戶在用什么樣的操作系統(tǒng),什么樣的瀏覽器,反過來,上網(wǎng)的人也不關(guān)心做網(wǎng)站的人在用什么的技術(shù)開發(fā)網(wǎng)站。但是大家在完全不關(guān)心對方的情況下,可以很正常地協(xié)同工作在一起。為什么?

這樣的例子太多了。為什么可以做成這樣呢?因為大家依賴的是一個接口,燈具和燈飾并不互相依賴,他們依賴的是一個接口,做網(wǎng)站的人和瀏覽網(wǎng)站的人依賴的還是接口——HTTP協(xié)議。這就是面向?qū)ο蟮暮诵乃枷?mdash;—依賴于接口而不是實現(xiàn),這就是觸耦。當(dāng)你看過這兩個例子以后,我希望你以后設(shè)計的軟件至少不能比我們現(xiàn)實社會中的這些方法要差。不然,你就是在讓社會倒退了,呵呵。

你會說,這和Unix,和應(yīng)對需求變化有什么關(guān)系?好讓我們再來看一下Unix的設(shè)計。

Unix設(shè)計的例子

下面是幾個Unix下的例子:

1、Unix下,所有的硬件都可以通過文件的方式存取。其統(tǒng)統(tǒng)在/dev下。于是,軟件和硬件的耦合被解開了,操作系統(tǒng)只需要把硬件統(tǒng)統(tǒng)變成文件,而程序只需要使用三個東西,一個是fd,一個是read(),一個是write(),就可以來操作任意的硬件了,這就是抽象,簡單到不行。

2、Unix下,所有的命令都可以用管道串起來(管道絕對是個偉大的發(fā)明),這樣,所有的命令間的交互全部解耦到只依賴于STD_IN, STD_OUT設(shè)備上。最酷的是,用戶可以使用管道任意地拼裝那些命令,以完成各式各樣的功能。管道這個設(shè)計思想可以映射為今天的Web Service,你可以任意地拼裝各種Web Service。

看到這里,你會發(fā)現(xiàn),這還是解耦,本質(zhì)上來說,也是一種依賴倒置——OOD的精髓。但是,Unix還不僅僅是這些。我們再來看幾個例子:

1、Unix下,軟件都是綠色地安裝。在iOS上更明顯——各個程序間基本上互不干擾,這個程序產(chǎn)生的垃圾文件不會影響到另一個程序。你刪到一個程序不會讓另一個程序不舉,各是各的空間。你可以刪除這些程序,只要把內(nèi)核心留著,系統(tǒng)照樣可以啟動。

2、Unix下,你可以通過設(shè)置一些環(huán)境變量,讓多種環(huán)境同時存在,比如:某個LAMP用的是Apache 2.0, Mysql 4.0, PHP 4.0,某個LAMP用的是Apache 2.2, Mysql 5.0,PHP5.3,你不但可以方便地在系統(tǒng)中切換這兩個環(huán)境,你甚至還可以同時啟動他們。

3、Unix下,你可以隨意地替換你想要的程序。比如,你不喜歡bash,你可以替換成ksh/csh等,你不喜歡awk,你可以替換成gawk,所有的東西都像零件一樣,你不喜歡什么,你就可以替換什么。

這三個例子告訴了我們——當(dāng)你把你的軟件設(shè)計地耦合度非常地低時,你可以隨意地組合,隨意地安排你的系統(tǒng)。想當(dāng)?shù)撵`活,靈活到Windows到今天都學(xué)不會。

應(yīng)對需求變化

看到這里,你可能明白我想說的是什么了,你可能開始覺得怎么樣的系統(tǒng)設(shè)計會更有效了。如果你還記得《Steve Y 對平臺的長篇大論》,你就會知道我想說什么了。是的,我想說的就是,當(dāng)你真正了解了Unix的設(shè)計思想后,你會覺得今天的這些東西都是對Unix設(shè)計思想的一種傳承或是變種。這種東西就是:

1)解耦,解耦,解耦。盡量地讓你的模塊不要在實現(xiàn)上耦合,而是耦合某個規(guī)范,某個標(biāo)準(zhǔn)。

2)KISS,KISS,KISS。要做到高度解耦,你的模塊就一定要很簡單,當(dāng)然不是說簡單到只有幾行代碼,而是簡單到只干一件事,并把這件事干到極致。然后通過某個標(biāo)準(zhǔn)拼裝起來。

3)拼裝,拼裝,拼裝。我想不起來是誰說的了,這句話是這樣的,當(dāng)我想用一個模塊的時候,我直接調(diào)用就好了,沒有必要像C或Java一樣,還要編譯。是的,拼裝需要一個框架,需要一種標(biāo)準(zhǔn)協(xié)議,然后讓所有的系統(tǒng)都耦合在這種規(guī)范上,各自獨立運行,就像一個機(jī)器上的各個部件一樣,當(dāng)我覺得這個部件不爽,換了就是了。(例如,當(dāng)我們在嘗試不用的算法的時候)

想想建材和家俱市場,無論用戶過來想裝修什么,我都可以滿足用戶的不同需求,只要你是和家裝相關(guān),我基本上都能滿足你,不是嗎?無論你怎么變,只要不變態(tài),我基本上都可以滿足你。這就是解耦,拼裝帶來的好處。

你可能會說我說得太簡單了,另一方面,你可能覺得有一些系統(tǒng)這樣做沒必要,我承認(rèn),不過,你可以有選擇的或多或少地試試。(其實,我相信你已經(jīng)在不自覺得或多或少地使用這種方式開發(fā)軟件了)

【編輯推薦】

  1. linux 與 unix 設(shè)計思想
  2. 如何克服Unix到Linux遷移的常見問題
  3. 從Unix到Linux的遷移部署:移植、升級和測試
責(zé)任編輯:Yeva 來源: Linuxeden
相關(guān)推薦

2010-05-05 17:45:12

IBM Unix

2012-04-01 10:14:27

linuxunix

2009-07-03 11:27:11

JSP編程思想

2010-08-19 09:48:41

Unix

2014-09-26 10:00:25

驅(qū)動設(shè)計DDD領(lǐng)域

2013-10-09 14:30:36

2011-06-07 08:58:31

javascript

2011-07-26 15:30:32

jQuery

2024-04-23 12:08:08

Arm

2009-11-13 09:44:27

LinuxUnixWin

2009-04-23 10:33:52

ASP.NET設(shè)計思想微軟

2021-08-02 07:57:03

設(shè)計系統(tǒng)客戶端

2023-12-01 08:09:08

2024-08-23 08:56:59

2015-08-13 22:25:52

OpenStack企業(yè)級云服務(wù)需求痛點

2013-03-01 11:19:02

項目需求項目設(shè)計

2022-12-07 15:43:39

5G6G網(wǎng)絡(luò)

2011-03-14 13:56:36

思科瞻博網(wǎng)絡(luò)Jawbreaker

2011-07-22 13:43:48

2023-10-07 15:56:49

三鏈表緩存頁flush鏈表
點贊
收藏

51CTO技術(shù)棧公眾號