|
最近在找工作,所以重新開始看書,重新整理知識體系,而現(xiàn)在上海的晚上很濕熱,睡不著,就產(chǎn)生了這些想法。
不說更早的歷史,就從dos開始說起。dos剛出來的時候是單進程的,根據(jù)人們的需求發(fā)展出了多進程的概念,而這種技術(shù)一直被保留到現(xiàn)在。現(xiàn)在的操作系統(tǒng)好像沒有單進程的系統(tǒng)了吧。那為什么要有多進程,為什么會有這樣的需求?比如你現(xiàn)在打開了word考試撰寫文檔,而又想要上網(wǎng)去查找一些資料,如果是單進程的,那就意味著打開了word就不能開IE,要開IE就要關(guān)掉word。那樣操作起來肯定會很麻煩。這個和編程的發(fā)展方向有什么關(guān)系呢?暫且繞開這個話題,先看看我們寫一個web網(wǎng)站是如何工作的。
web的工作方式,肯定需要是有一個宿主(專業(yè)點的說話,比如IIS、Apache等),然后寫一段程序,把這個程序配置到宿主中,就可以訪問了。 那什么是宿主,它在做哪些事情?剛才都說了宿主就是比如IIS之類的程序,可以理解為一個容器,它有一些接口,只要滿足這個接口規(guī)定的程序,就可以在這個宿主中運行。為什么我們寫的一面一定要以ASPx后綴結(jié)尾?為什么ASPx頁面里不能寫匯編?這個可以理解為一種協(xié)議。怎么理解這個協(xié)議的作用呢?那就要知道IIS所扮演的角色。當(dāng)你訪問IIS某個站點的某個文件的時候,它就知道去哪里、以什么方式來運行所要做的事情。這個和C#里接口的概念很相似,你只要滿足接口,那么就可以扔到一個上下文中去執(zhí)行。
假如,你來開發(fā)一個宿主,需要做些什么?首先,需要寫Socket偵聽,偵聽到連接,開始接收請求的數(shù)據(jù)(HTTP協(xié)議消息),然后解析消息,按解析結(jié)果執(zhí)行,最后返回結(jié)果。大致這么幾個過程。而所有的人都在請求這個IIS,這就是聚焦。用戶使用的客戶端是發(fā)散的,而所有的請求,都會聚焦到這個點上。這個聚焦的點,在IIS內(nèi)部就是Socket?事實上不能這樣理解。HTTP請求所用的Socket是一對一的,也就是說,每個用戶請求IIS之后,IIS內(nèi)部對每個請求有一個隔離。每個用戶都有自己當(dāng)前請求的上下文,這個上下文是獨立的,而我們的代碼只有一份,所以的請求,運行的進程、線程,代碼對它們來說就是聚焦的。就是說,現(xiàn)在我們開發(fā)的web應(yīng)用,是在維護一份代碼,而讓他們可以發(fā)散地(多線程、進程地)工作。事實上,單機程序,c/s架構(gòu)也是和web的開發(fā)方式一樣的。開發(fā)人員不會為每個人開發(fā)獨立的應(yīng)用,至于個性化,那是軟件的一部分。
這個道理誰都懂,上面的分析有點畫蛇添足的味道,無量天尊!~~~
事實上我們開發(fā)的應(yīng)用,不全是那樣。比如靜態(tài)變量等全局應(yīng)用,是在運行時唯一的。在處理這些全局?jǐn)?shù)據(jù)時,我們一般會lock,和數(shù)據(jù)庫應(yīng)用的悲觀鎖是一個概念。這個地方就會產(chǎn)生一個問題,全局?jǐn)?shù)據(jù)會影響所有人的響應(yīng),一旦全局?jǐn)?shù)據(jù)出錯,那是致命的。這就是我們這里要講的聚焦效應(yīng)。靜態(tài)數(shù)據(jù)是運行期有聚焦效應(yīng),而代碼就是編碼期有聚焦效應(yīng),并且這個效應(yīng)更加明顯。對一處代碼的改動可能會影響很多地方,那么這里的代碼就是聚焦的。在C#編程中可以理解為,接口、超類、生產(chǎn)者都是聚焦的。這個焦點改變了,那么影響是巨大的。可以想象下,凸透鏡的焦距發(fā)生變化,要保證焦點不變,那么光源的光線就要全部變化。為了適應(yīng)這種變化,各種理論發(fā)展起來,而OO就是其中之一。OO的多態(tài)是在擁抱變化,而這個過程就是發(fā)散的過程。
假設(shè),現(xiàn)在開發(fā)的應(yīng)用都毫不相干,沒有任何可以提取公用的部分,也就是說,提不出接口,泛化不出超類,那整個代碼都是發(fā)散的。而OO里面很關(guān)鍵的就是要提取不變的部分,設(shè)計會變的部分,這是代碼重用里最重要的思想,我是這么認(rèn)為的。我認(rèn)為這就是一種聚焦思維,而未來一段時間編程的發(fā)展也會朝著這個方向發(fā)展。如果認(rèn)為一個系統(tǒng)哪個地方都需要變化,那就根本沒有代碼重用的可能。而事實上,一個軟件的代碼中總有能重用的代碼,那就是說總有不變的代碼,總有聚焦的地方。這是不變代碼的聚焦,對于變化的部分,我們也在尋求聚焦點,而這個過程需要作好設(shè)計。
對于變動的代碼,有兩種開發(fā)的方式。一個是提供服務(wù)的,而另一個是享受服務(wù)的。這句話怎么說呢?比如,在C#開發(fā)中,調(diào)用.NET Framework類庫,那就是享受服務(wù),這個是發(fā)散的。而提供服務(wù)最容易想到的就是工廠模式和委托。和在網(wǎng)站開發(fā)中模板的方式類似,在網(wǎng)頁中設(shè)置一個替換符號,用內(nèi)容來填充這個符號。委托也是這樣,在一個應(yīng)用中,定義了一個方法執(zhí)行這個委托,我們不知道他的工作方式,但是我們已經(jīng)在使用它,這應(yīng)該算是一種逆向的思維。插件架構(gòu)就是這樣工作的,由配置來決定調(diào)用哪個類。而聚焦點就在這個超類或接口。
最后,可以看出,編寫代碼一共有三種方式。
第一、不會變化的,這是絕對聚焦的代碼,一旦改變,后果不堪設(shè)想;
第二、類庫式的,這是發(fā)散式的代碼,類庫不能控制你怎么提取焦點;
第三、框架式的,這個是聚焦于接口或超類的代碼,不變動接口和超類,還是可以接受的。
it知識庫:聚焦與發(fā)散——淺談編程的發(fā)展方向,轉(zhuǎn)載需保留來源!
鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。