中文字幕二区_国产精品免费在线观看_黄色网站观看_人人草人人澡_日本真实娇小xxxx

您的位置: 首頁 > 技術(shù)文檔 > 網(wǎng)頁制作 > 從if else到switch case再到抽象
一場關(guān)于YUI3/jQuery的精彩辯論 回到列表 Flash在多標簽瀏覽器中的問題
 從if else到switch case再到抽象

作者:Cat Chen 時間: 2010-11-05 文檔類型:合作網(wǎng)站提供 來自:百度泛用戶體驗

第 1 頁 從if else到switch case再到抽象 [1]
第 2 頁 從if else到switch case再到抽象 [2]
第 3 頁 從if else到switch case再到抽象 [3]

大家覺得在接手遺留代碼時,見到什么東東是最讓人感到不耐煩的?復雜無比的 UML ?我覺得不是。我的答案是,超過兩個 else 的 if ,或者是超過兩個 case 的 switch ?墒窃诖a中大量使用 if elseswitch case 是很正常的事情吧?錯!絕大多數(shù)分支超過兩個的 if else 和 switch case 都不應(yīng)該以硬編碼( hard-coded )的形式出現(xiàn)。

復雜分支從何而來

首先我們要討論的第一個問題是,為什么遺留代碼里面往往有那么多復雜分支。這些復雜分支在代碼的首個版本中往往是不存在的,假設(shè)做設(shè)計的人還是有點經(jīng)驗的話,他應(yīng)該預(yù)見將來可能需要進行擴展的地方,并且預(yù)留抽象接口。

但是代碼經(jīng)過若干個版本的迭代以后,尤其是經(jīng)過若干次需求細節(jié)的調(diào)整以后,復雜分支就會出現(xiàn)了。需求的細節(jié)調(diào)整,往往不會反映到 UML 上,而會直接反映到代碼上。例如說,原本消息分為聊天消息和系統(tǒng)消息兩類,設(shè)計的時候自然會把這設(shè)計為消息類的兩個子類。但接著有一天需求發(fā)生細節(jié)調(diào)整了,系統(tǒng)消息里面有一部分是重要的,它們的標題要顯示為紅色,這時候程序員往往會做如下修改:

在系統(tǒng)消息類上面加一個 important 屬性

在相應(yīng)的 render 方法里面加入一個關(guān)于 important 屬性的分支,用于控制標題顏色
程序員為什么會作出這樣的修改?有可能因為他沒意識到應(yīng)該抽象。因為需求說的是「系統(tǒng)消息里面有一部分是重要的」,對于接受命令式編程語言訓練比較多的程序員來說,他或許首先想到的是標志位──一個標志位就可以區(qū)分重要跟不重要。他沒想到這個需求可以用另一種方式來解讀,「系統(tǒng)消息分為重要和不重要兩種類別」。這樣子解讀,他就知道應(yīng)該對系統(tǒng)消息進行抽象了。

當然也有可能,程序員知道可以抽象,但基于某些原因,他選擇了不這樣做。很常見的一種情況就是有人逼著程序員,以犧牲代碼質(zhì)量來換取項目進展速度──加入一個屬性和一個分支,遠比抽象重構(gòu)要簡單得多,如果要做10個這種形式的修改,是做10個分支快還是做10個抽象快?區(qū)別顯而易見。

當然, if else 多了,就有聰明人站出來說「不如我們改成 switch case 」吧。在某些情況下,這確實能夠提升代碼可讀性,假設(shè)每一個分支都是互斥的話。但是當 switch case 的數(shù)量也多起來以后,代碼一樣會變得不可讀。

復雜分支有何壞處

復雜分支有什么壞處?讓我從百度 Hi 網(wǎng)頁版的老代碼里面截取一段出來做個例子。

switch (json.result) {
  case "ok":
    switch (json.command) {
      case "message":
      case "systemmessage":
        if (json.content.from == ""
          && json.content.content == "kicked") {
          /* disconnect */
        } else if (json.command == "systemmessage"
          || json.content.type == "sysmsg") {
          /* render system message */
        } else {
          /* render chat message */
        }
        break;
    }
    break;

出處:百度泛用戶體驗
責任編輯:bluehearts

上一頁 下一頁 從if else到switch case再到抽象 [2]

◎進入論壇網(wǎng)頁制作WEB標準化版塊參加討論,我還想發(fā)表評論

相關(guān)文章
Photoshop打造抽象表現(xiàn)主義效果
Photoshop 繪制抽象紅花
超現(xiàn)代抽象畫欣賞
關(guān)鍵字搜索 常規(guī)搜索 推薦文檔
熱門搜索:CSS Fireworks 設(shè)計比賽 網(wǎng)頁制作 web標準 用戶體驗 UE photoshop Dreamweaver Studio8 Flash 手繪 CG
站點最新 站點最新列表
周大!熬•自然”設(shè)計大賽開啟
國際體驗設(shè)計大會7月將在京舉行
中國國防科技信息中心標志征集
云計算如何讓安全問題可控
云計算是多數(shù)企業(yè)唯一擁抱互聯(lián)網(wǎng)的機會
阿里行云
云手機年終巨獻,送禮標配299起
阿里巴巴CTO王堅的"云和互聯(lián)網(wǎng)觀"
1499元買真八核 云OS雙蛋大促
首屆COCO桌面手機主題設(shè)計大賽
欄目最新 欄目最新列表
淺談JavaScript編程語言的編碼規(guī)范
如何在illustrator中繪制臺歷
Ps簡單繪制一個可愛的鉛筆圖標
數(shù)據(jù)同步算法研究
用ps作簡單的作品展示頁面
CSS定位機制之一:普通流
25個最佳最閃亮的Eclipse開發(fā)項目
Illustrator中制作針線縫制文字效果
Photoshop制作印刷凹凸字體
VS2010中創(chuàng)建自定義SQL Rule
>> 分頁 首頁 前頁 后頁 尾頁 頁次:1/31個記錄/頁 轉(zhuǎn)到 頁 共3個記錄

藍色理想版權(quán)申明:除部分特別聲明不要轉(zhuǎn)載,或者授權(quán)我站獨家播發(fā)的文章外,大家可以自由轉(zhuǎn)載我站點的原創(chuàng)文章,但原作者和來自我站的鏈接必須保留(非我站原創(chuàng)的,按照原來自一節(jié),自行鏈接)。文章版權(quán)歸我站和作者共有。

轉(zhuǎn)載要求:轉(zhuǎn)載之圖片、文件,鏈接請不要盜鏈到本站,且不準打上各自站點的水印,亦不能抹去我站點水印。

特別注意:本站所提供的攝影照片,插畫,設(shè)計作品,如需使用,請與原作者聯(lián)系,版權(quán)歸原作者所有,文章若有侵犯作者版權(quán),請與我們聯(lián)系,我們將立即刪除修改。

您的評論
用戶名:  口令:
說明:輸入正確的用戶名和密碼才能參與評論。如果您不是本站會員,你可以注冊 為本站會員。
注意:文章中的鏈接、內(nèi)容等需要修改的錯誤,請用報告錯誤,以利文檔及時修改。
不評分 1 2 3 4 5
注意:請不要在評論中含與內(nèi)容無關(guān)的廣告鏈接,違者封ID
請您注意:
·不良評論請用報告管理員,以利管理員及時刪除。
·尊重網(wǎng)上道德,遵守中華人民共和國的各項有關(guān)法律法規(guī)
·承擔一切因您的行為而直接或間接導致的民事或刑事法律責任
·本站評論管理人員有權(quán)保留或刪除其管轄評論中的任意內(nèi)容
·您在本站發(fā)表的作品,本站有權(quán)在網(wǎng)站內(nèi)轉(zhuǎn)載或引用
·參與本評論即表明您已經(jīng)閱讀并接受上述條款
推薦文檔 | 打印文檔 | 評論文檔 | 報告錯誤  
專業(yè)書推薦 更多內(nèi)容
網(wǎng)站可用性測試及優(yōu)化指南
《寫給大家看的色彩書1》
《跟我去香港》
眾妙之門—網(wǎng)站UI 設(shè)計之道
《Flex 4.0 RIA開發(fā)寶典》
《贏在設(shè)計》
犀利開發(fā)—jQuery內(nèi)核詳解與實踐
作品集 更多內(nèi)容

雜⑦雜⑧ Gold NORMANA V2