• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            Dict.CN 在線詞典, 英語學習, 在線翻譯

            學海苦作舟,書山勤為徑

            留下點回憶

            常用鏈接

            統計

            積分與排名

            Denoise

            English study

            Web技術

            數據壓縮

            一些連接

            最新評論

            重構-代替類型代碼幾中方式的比較(Replace type code with ...)

            在重構中對類型編碼有一些專用的重構方法,其中有使用類、子類、和狀態\策略模式三種方式,這里對他們進行分析和比較。

            說明一下:類型編碼(type code)是一些常量或變量,一般有多個可能的值;這么說可能還不明白,看下面吧。

            首先說使用類來消除類型代碼吧。這種類型代碼,一般都有定義好的常量值,例如血型(A,B,O等),但具體的類行為不會因為這些編碼值不同而不同,也就是說這些編碼僅僅作為類的一個信息的反映吧。不過還的對這些類型進行設置和查詢,其作為參數存在的時候,我們可能提供定義的別名(const int A = 0;)來作為參數,但編譯器處理的時候可能還是按照數值來的(#define  0 A)或者頂多提示變量的名稱,但我們也許不清楚錯誤的來源,如果使用一個單獨的類將這些值作為類的靜態成員封裝起來使用,那么使用的時候就有完整的名稱來標示了,例如:BloodGroup::A,這個比單獨的一個A好理解,另外如果編譯器報錯,也會定位到BloodGroup類了。總之我覺得這種重構手法是為了增加代碼的可讀性,記住適合的條件:不影響類的行為。

            那么第二種就是影響類的行為的類型代碼了。比如下面的代碼:

            if(a =1) ...; else  if....

            switch(i){case 1:; case 2:;...}

            可以看的出來,這種情況的類型代碼已經對我們的類帶來不同的行為,而我們也發現類型編碼的值在運行的時候是不變化的,這個時候面向對象的一大特性多態就有幫助了。我們為該類建立子類,將使用到該類型編碼的方法設置為虛方法,在子類中進行各自不同的實現。這里有個問題,就是條件判斷會在某個地方存在,但子類話的好處有多個:首先符合面向對象的思想,其次我們只需要在一個地方判斷條件,如果不這樣,我們可能到處都要判斷條件;最后就是對子類的修改不影響其他子類的行為。

            好了,如果類型代碼對類的行為產生影響而且其自身的狀態也在生存期變化,這個時候就該使用第三種方法了:狀態或策略模式,這兩個模式說明的很清楚,專門對付多條件和狀態變化的情況。這個時候原來的擁有一個對象成員,該對象是一個指向某種子類的指針或引用,這個指針在運行期是可變的,從而達到不改變原對象的本身類型來滿足需求。例如:員工有許多級別,不同級別有不同的行為,而員工的級別是可以改變的。我們將級別作為員工的一個屬性,通過改變級別指向不同的級別子類來得到改變員工身份和行為需要。其實,在按照狀態/策略模式重構后,還可以對齊進行多態的重構。

            另外,對于避免switch的情況生成不同的子類,需要建立一個查詢表,提供類型編碼查詢得到生成子類的名稱,最后根據類型的名稱來得到生成該子類對象(我知道JAVA可以實現),這樣可以保證代碼更靈活,但總是需要有一個地方做對應,不過比在代碼中做對應要好些。

            好了,具體的還的看書,這里只是簡單的介紹。

            posted on 2005-11-11 13:22 笨笨 閱讀(1104) 評論(3)  編輯 收藏 引用 所屬分類: 代碼重構

            評論

            # re: 重構-代替類型代碼幾中方式的比較(Replace type code with ...) 2006-08-13 13:10 LOGOS

            嗯.看了LZ所說,想到的極端做法是,凡是有switch的地方,都用virtual function代替.  回復  更多評論   

            # re: 重構-代替類型代碼幾中方式的比較(Replace type code with ...) 2008-07-25 17:21 圣斗士皮皮

            @LOGOS
            想到的做法是表驅動法  回復  更多評論   

            # re: 重構-代替類型代碼幾中方式的比較(Replace type code with ...) 2010-01-05 16:43 vg

            用類來封裝類型,帶來了好處,但需要創建對象,一旦創建就需要管理  回復  更多評論   

            人妻少妇精品久久| 精品久久久久久国产| 国内精品久久久久| 69久久精品无码一区二区| 亚洲国产天堂久久综合网站| 国产999精品久久久久久| 久久久免费观成人影院 | 精品久久久久久国产| 久久久久亚洲AV无码麻豆| 免费国产99久久久香蕉| 中文字幕久久亚洲一区| 国产精品一区二区久久不卡| 国产亚洲精久久久久久无码AV| 国产精品久久久香蕉| 国产精品永久久久久久久久久| 亚洲精品美女久久777777| 久久激情亚洲精品无码?V| 久久久免费精品re6| 久久久国产99久久国产一| 99久久国产综合精品网成人影院 | 欧美无乱码久久久免费午夜一区二区三区中文字幕 | 久久香蕉国产线看观看乱码| 性做久久久久久久久| 久久婷婷久久一区二区三区| 国产69精品久久久久9999APGF | 久久人人爽人人爽人人片av麻烦 | 国内精品久久人妻互换| 久久久久久国产精品美女| 国产视频久久| 色综合合久久天天综合绕视看| 久久天天躁狠狠躁夜夜avapp| 久久久久香蕉视频| 91久久精品国产成人久久| 国产三级久久久精品麻豆三级| 区久久AAA片69亚洲| 久久久久亚洲AV成人网人人网站 | 国内精品免费久久影院| 中文字幕一区二区三区久久网站| 久久人妻少妇嫩草AV无码专区| 一本色道久久88精品综合 | 亚洲午夜无码久久久久|