日韩无码专区无码一级三级片|91人人爱网站中日韩无码电影|厨房大战丰满熟妇|AV高清无码在线免费观看|另类AV日韩少妇熟女|中文日本大黄一级黄色片|色情在线视频免费|亚洲成人特黄a片|黄片wwwav色图欧美|欧亚乱色一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
為什么面向?qū)ο笤阃噶耍?/div>

 又是周末,編程語言“三巨頭”Java, Lisp 和C語言在Hello World咖啡館聚會(huì)。

成都創(chuàng)新互聯(lián)堅(jiān)持“要么做到,要么別承諾”的工作理念,服務(wù)領(lǐng)域包括:做網(wǎng)站、網(wǎng)站設(shè)計(jì)、企業(yè)官網(wǎng)、英文網(wǎng)站、手機(jī)端網(wǎng)站、網(wǎng)站推廣等服務(wù),滿足客戶于互聯(lián)網(wǎng)時(shí)代的花垣網(wǎng)站設(shè)計(jì)、移動(dòng)媒體設(shè)計(jì)的需求,幫助企業(yè)找到有效的互聯(lián)網(wǎng)解決方案。努力成為您成熟可靠的網(wǎng)絡(luò)建設(shè)合作伙伴!

服務(wù)員送來咖啡的同時(shí)還帶來了一張今天的報(bào)紙, 三人寒暄了幾句, C語言翻開了報(bào)紙,突然眼前一亮:“這篇文章的標(biāo)題寫得好啊, 《為什么面向?qū)ο笤阃噶?》”

(這是一篇很早之前的文章,作者是大名鼎鼎的Joe Armstrong , 也就是Erlang之父。)

Java 大吃一驚,居然有人這么罵面向?qū)ο?!

他趕緊搶過來,看了一會(huì)兒,說到:“雖然我對去世的Joe Armstrong老先生非常尊敬,但是我對他的觀點(diǎn)卻不敢茍同,你看他說'數(shù)據(jù)結(jié)構(gòu)和函數(shù)不應(yīng)該綁到一起!'”

C語言說:“他說得很有道理啊,函數(shù)是實(shí)現(xiàn)算法的,就像一個(gè)黑盒子,只要理解了它的輸入和輸出,就理解了它的功能,而數(shù)據(jù)結(jié)構(gòu)呢就是單純的‘聲明’,為什么要把他們綁在一起呢?”

“不不不,還是綁在一起好!我給你舉個(gè)例子,一個(gè)棧,如果你把它當(dāng)成一個(gè)完整的對象,那用起來就方便多了。”

 
 
 
 
  1. Stack s = new Stack(); 
  2. s.push(100); 
  3. s.push(200); 
  4. s.pop(); 

C語言不甘示弱:“把數(shù)據(jù)結(jié)構(gòu)和函數(shù)分開也挺好啊!比如我可以創(chuàng)建一個(gè)叫做Stack的數(shù)據(jù)結(jié)構(gòu),然后寫幾個(gè)對這個(gè)數(shù)據(jù)結(jié)構(gòu)操作的函數(shù)?!?/p>

 
 
 
 
  1. push(stack, 100); 
  2. push(stack, 200); 
  3. pop(stack); 

Java不屑一顧地說:“你看看你這種方式多丑陋啊?!?/p>

C語言寸步不讓:“本質(zhì)都是一樣的,你是o.f() ,我是f(o), 有啥區(qū)別?”

Lisp也插了一嘴:“還有我的(f o) ”

2

Java無語,心說這兩個(gè)家伙就是胡攪蠻纏。突然,他心中一動(dòng):我怎么忘記多態(tài)了。

Java說:“本質(zhì)是不一樣的,你要知道,o.f()是可以產(chǎn)生多態(tài)行為的,這就帶來了巨大的好處,我給你舉個(gè)例子,你有一段業(yè)務(wù)邏輯,需要把計(jì)算的結(jié)果記錄到文件中,將來還可能會(huì)記錄別的地方,你的設(shè)計(jì)可能是這樣的?!?/p>

C語言:“難道不應(yīng)該如此嗎?一個(gè)函數(shù)調(diào)用另外一個(gè)函數(shù)?”

Java 說到:“這里有個(gè)依賴的問題,就是businessLogic()不但運(yùn)行期依賴writeToFile(), 在源碼級或者編譯期也會(huì)依賴?!?/p>

C語言:“這不是很正常嘛!”

Java又說道:“不一樣, 寫入文件是底層的實(shí)現(xiàn)細(xì)節(jié),不是高層策略,假如用戶不想把計(jì)算的結(jié)果保存到文件中了,而是想通過郵件發(fā)送,那你的businessLogic也得修改了,對不對?”

C語言:“那肯定啊!函數(shù)調(diào)用嘛,一個(gè)改了,另外一個(gè)也得改?!?/p>

“這就是問題了, 編譯期/源代碼的依賴導(dǎo)致我們沒法把系統(tǒng)劃分成獨(dú)立的組件,各自獨(dú)立開發(fā),獨(dú)立部署,一個(gè)的變化就影響到了另外一個(gè)。”

C語言覺得有一定的道理,他說:“那怎么辦?”

Java說:“你看看我使用多態(tài)以后的設(shè)計(jì),我的業(yè)務(wù)邏輯在編譯時(shí)只依賴那個(gè)接口Writer,而不依賴具體的實(shí)現(xiàn)FileWriter和MailWriter。”

“你的意思是只要接口Writer不變化,底層的具體實(shí)現(xiàn)如FileWriter ,MailWriter可以隨意變化,隨意替換,就像插件一樣,對吧?” C語言說到。

“對啊,編譯期/源代碼不依賴,運(yùn)行期依賴,這就是延遲綁定帶來的好處,現(xiàn)在你明白o(hù).f()和 f(o)的本質(zhì)區(qū)別了吧。 ”

Lisp 不失時(shí)機(jī)又插了一嘴:“你那接口中只有一個(gè)函數(shù),就是write(),用什么接口啊,脫褲子放屁,多此一舉,在我這兒只要把不同的函數(shù)傳遞過去就可以了。”

Java笑道:“別抬杠,這就是個(gè)簡單的例子,不管是用接口,還是傳遞函數(shù),都是延遲綁定嘛, 關(guān)鍵點(diǎn)都是要找到那個(gè)穩(wěn)定的東西(Writer),就是抽象。你找不到這個(gè)穩(wěn)定的東西,做不出抽象,你的系統(tǒng)就沒法劃分成可以獨(dú)立開發(fā),獨(dú)立變化的組件了?!?/p>

C語言還想反擊,但一直找不到突破口。

Lisp說道:“別聽Java在哪里忽悠,C老弟,你也能實(shí)現(xiàn)運(yùn)行期的延遲綁定,這不是Java的專利,你忘了虛函數(shù)表了?”

C語言一拍大腿:“是啊,我忘了那一年春節(jié)回家,Linus 大神曾經(jīng)告訴我,虛函數(shù)表和函數(shù)指針才是實(shí)現(xiàn)多態(tài)的關(guān)鍵,比如Unix/Linux把設(shè)備都當(dāng)成了文件,有標(biāo)準(zhǔn)的open , read 等方法,對于不同的設(shè)備,都能調(diào)用對應(yīng)的方法, 那是怎么實(shí)現(xiàn)的?也是通過虛函數(shù)表做延遲綁定嘛!”

C語言高興了:“哈哈,Java 老弟,看來我們本質(zhì)上還是一樣的,多態(tài)只不過是函數(shù)指針的一種應(yīng)用!”

Java說:“所以編程的關(guān)鍵不在于是否使用了面向?qū)ο蟮恼Z言,這一點(diǎn)你同意吧?”

C語言點(diǎn)頭,編程的關(guān)鍵點(diǎn)就是找到、抽象出穩(wěn)定的接口,針對這個(gè)接口編程,這樣就可以讓各個(gè)模塊能夠獨(dú)立地變化。

3

“說起來容易,做起來難,這兒有一個(gè)例子,你給我用面向?qū)ο笤O(shè)計(jì)一下?” Lisp 拋出了一道題。

動(dòng)物可以分為肉食動(dòng)物,草食動(dòng)物,水生動(dòng)物,陸生動(dòng)物,用類如何表示?

Java 說:這還不簡單,看看這名詞多明顯啊,都可以變成類啊,讓他們都繼承動(dòng)物就可以了。

Lisp看到Java 掉入了陷阱,狡黠地一笑:“那有的動(dòng)物就既是陸生動(dòng)物,又是肉食動(dòng)物,怎么表達(dá)?”

“那我就加一個(gè)陸生肉食動(dòng)物類?!?雖然覺得不妥,Java還是說了出來。

“那要是再來一個(gè)水生肉食動(dòng)物怎么辦?或者來了一個(gè)新的概念‘哺乳動(dòng)物’, 該怎么處理?”

“哈哈哈,我懂了,隨著需求的增多,不但類會(huì)出現(xiàn)爆炸, 還可能會(huì)出現(xiàn)那種怪異的類,這面向?qū)ο缶幊檀_實(shí)是有大問題啊!” C語言說。

Java 低頭沉思不語,突然,腦海中想起來了那句話:優(yōu)先使用組合而不是繼承。

怎么使用組合?必須得改變下看待問題的方式,對,應(yīng)該這樣:

Java得意地說:“看看這個(gè)圖, 動(dòng)物具備多個(gè)特性,如'進(jìn)食', '移動(dòng)',將來還可以加上'哺乳方式',每個(gè)特性都是一個(gè)接口,接口是穩(wěn)定的, 動(dòng)物這個(gè)概念是可以通過這些接口特性給組合起來的?!?/p>

Lisp 贊賞地點(diǎn)頭, C語言向Java投去了欽佩的目光,這家伙經(jīng)常做面向?qū)ο蟮脑O(shè)計(jì),還是有兩把刷子的,他通過特性的方式把變化給隔離了, 各個(gè)特性可以通過組合的方式,像插件一樣隨意替換, 嗯,這才是面向?qū)ο蟮恼嬲璋 ?/p>

夜已深, 最后Java做了個(gè)總結(jié),大伙散去。

“編程嘛就是發(fā)現(xiàn)變化,并且把它給隔離起來,使用各種語言都可以,面向?qū)ο蟮恼Z言有著直接使用多態(tài)的便利,以后不要隨隨便便就diss它了。”

參考資料:

http://www.cs.otago.ac.nz/staffpriv/ok/Joe-Hates-OO.htm

《敏捷軟件開發(fā):原則,模式與實(shí)踐》

《架構(gòu)整潔之道》

《面向?qū)ο箝_發(fā)參考手冊》

【本文為專欄作者“劉欣”的原創(chuàng)稿件,轉(zhuǎn)載請通過作者微信公眾號coderising獲取授權(quán)】

戳這里,看該作者更多好文


分享名稱:為什么面向?qū)ο笤阃噶耍?
分享鏈接:http://www.5511xx.com/article/djcijsj.html