• <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>
            SmartPtr
            本博客已搬至:http://www.cnblogs.com/baiyanhuang/
            posts - 29,comments - 176,trackbacks - 0
            By SmartPtr(http://www.shnenglu.com/SmartPtr/)

            粒度:包的內(nèi)聚性原則
            1) 重用發(fā)布等價(jià)原則(The Release Reuse Equivalency Principle (REP))

            * 重用的粒度就是發(fā)布的粒度
            * 一個(gè)可重用的包必須為發(fā)布跟蹤系統(tǒng)所管理,使我們?cè)谛掳姹景l(fā)布后我們還可以繼續(xù)使用老版本
            * 一個(gè)包中的所有類對(duì)于同一類用戶來(lái)講都應(yīng)該是可重用的。

            2) 共同重用原則(The Common Reuse Principle (CRP))
            * 一個(gè)包中的所有類應(yīng)該是共同重用的,如果重用了包中的一個(gè)類,就應(yīng)該重用包中的所有類。
            * 一般來(lái)說(shuō),可重用的類需要與作為該可重用抽象一部份的其它類協(xié)作,CRP規(guī)定了這些類應(yīng)該屬于同一個(gè)包。
            * 放入同一包中的所有類應(yīng)該是不可分開(kāi)的,其它包僅僅依賴于其中一部份情況是不可能的(不允許的),否則,我們將要進(jìn)行不必要的重新驗(yàn)證與重新發(fā)布,并且會(huì)白費(fèi)相當(dāng)數(shù)量的努力。(一個(gè)包依賴于另外一個(gè)包, 哪怕只是依賴于其中的一個(gè)類也不會(huì)削弱其依賴關(guān)系)
            * CRP傾向于把包做的盡可能的小

            3) 共同封閉原則(The Common Closure Principle (CCP))
            * 包中的所有類對(duì)于同一類性質(zhì)的變化應(yīng)該是共同封閉的。一個(gè)變化若對(duì)一個(gè)包產(chǎn)生影響,則將對(duì)該包中所有類產(chǎn)生影響,而對(duì)于其他的包不造成任何影響。
            * 這是單一職責(zé)原則對(duì)于包的重新規(guī)定。
            * CCP鼓勵(lì)我們把可能由于同樣的原因而更改的所有類共同聚集在同一個(gè)地方。將變化限制在最小數(shù)據(jù)的包中。
            * CCP傾向于將包做的盡可能的大。
            * CCP有益于維護(hù)者(包的作者),而REP和CRP有益于重用者(包的使用者)。

            穩(wěn)定性:包的耦合性原則
            4) 無(wú)環(huán)依賴原則(The Acyclic Dependencies Principle (ADP))
            * 在包的依賴關(guān)系圖中不允許存在環(huán)。
            * 包的依賴關(guān)系圖應(yīng)該是一個(gè)有向無(wú)環(huán)圖(DAG(Directed Acyclic Grphic))
            * 存在環(huán)的系統(tǒng),很難確定包的構(gòu)建順序,事實(shí)上,并不存在恰當(dāng)?shù)臉?gòu)建順序。
            * 打破環(huán)的第一個(gè)方法:依賴倒置原則,使一個(gè)包不再依賴于另一個(gè)包,而只是依賴于其抽象接口。
            * 打破環(huán)的第二個(gè)方法: 創(chuàng)建一個(gè)新包來(lái)包含公共依賴部份。

            5) 穩(wěn)定依賴原則(The Stable Dependencies Principle (SDP))
            * 朝著的穩(wěn)定的方向進(jìn)行依賴
            * 你設(shè)計(jì)了一個(gè)易于更改的包, 其它人只要?jiǎng)?chuàng)建一個(gè)對(duì)它的依賴就可以使它變的難以更改,這就是軟件的反常特性。通過(guò)遵循SDP可以避免這種情況。
            * 不穩(wěn)定性度量:I = Ce / (Ca + Ce). Ca: Afferent Coupling. Ce: Efferent Coupling
            * SDP規(guī)定一個(gè)包的I度量值應(yīng)該大于它所依賴的包的I的度量值,也就是說(shuō),I的度量值應(yīng)該順著依賴的方向減少。

            6) 穩(wěn)定抽象原則(The Stable Abstractions Principle (SAP))
            * 包的抽象程度應(yīng)該和其穩(wěn)定程度一致。
            * 一個(gè)穩(wěn)定的包同時(shí)應(yīng)該是抽象的,這樣,其穩(wěn)定性就不會(huì)導(dǎo)致其無(wú)法擴(kuò)展。一個(gè)不穩(wěn)定的包應(yīng)該是具體的,這樣,因?yàn)槠洳环€(wěn)定性使得其內(nèi)部的具體代碼易于修改。
            * 抽象性度量:A = Na / Nc Na: Number of classes. Nc:Number of abstract classes.
            * 創(chuàng)建一個(gè)以A為縱軸,I為橫軸的坐標(biāo)圖,最穩(wěn)定,最抽象的包位于左上角(0,1)處, 那些最不穩(wěn)定,最具體的包位于右下角(1,0)處。



            posted on 2007-08-26 21:09 SmartPtr 閱讀(1000) 評(píng)論(2)  編輯 收藏 引用

            FeedBack:
            # re: 包的設(shè)計(jì)原則
            2007-08-29 10:11 | Anders06
            包的這幾個(gè)原則到?jīng)]仔細(xì)去看過(guò).

            <<敏捷軟件開(kāi)發(fā)>>看過(guò)了吧,記得我發(fā)過(guò)ebook給你的,,很贊的一本書

            kao, 又說(shuō)我驗(yàn)證碼錯(cuò)誤....  回復(fù)  更多評(píng)論
              
            # re: 包的設(shè)計(jì)原則
            2007-09-07 13:30 | SmartPtr
            那本書還沒(méi)看過(guò)。。。
              回復(fù)  更多評(píng)論
              

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理


            久久久久亚洲精品中文字幕| 久久99国产精一区二区三区| 久久久久亚洲?V成人无码| Xx性欧美肥妇精品久久久久久| 很黄很污的网站久久mimi色 | 青青草原综合久久大伊人精品| 久久国产亚洲精品麻豆| 久久久久九国产精品| 日韩精品久久无码中文字幕| 伊人久久大香线蕉精品| 精品久久久中文字幕人妻| 老司机国内精品久久久久| 亚洲人成电影网站久久| 久久精品国产亚洲麻豆| 97精品伊人久久久大香线蕉 | 一本久道久久综合狠狠爱| 久久久久久综合一区中文字幕 | 久久人人爽人人爽人人爽| 9久久9久久精品| 久久精品国产2020| 久久中文字幕无码专区| 久久夜色tv网站| 久久99精品久久久久子伦| 亚洲综合日韩久久成人AV| 综合久久给合久久狠狠狠97色| 91久久精品电影| 国产成人香蕉久久久久| 国产精品欧美久久久天天影视 | 精品久久一区二区三区| 丁香五月网久久综合| 久久精品国产99久久久| 久久亚洲精品成人AV| 色欲久久久天天天综合网精品| 伊人久久大香线蕉精品不卡| 久久亚洲AV无码西西人体| 久久国产精品免费一区二区三区| 久久精品国产99国产精偷| 国产美女久久精品香蕉69| 97热久久免费频精品99| 国内精品久久九九国产精品| 999久久久免费精品国产|