• <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>
            隨筆-34  評論-108  文章-0  trackbacks-0
                抽象是一種以簡化的形式來看待復(fù)雜操作的能力,類的接口為隱藏在其后的具體實現(xiàn)提供了一種抽象,類的接口應(yīng)能提供一組明顯相關(guān)的子程序。
                如果類的接口不能展現(xiàn)出一直的抽象,那么它的內(nèi)聚性就很弱,應(yīng)該考慮把一些子程序重新組織到只能更專一的類里去,在這些類的接口中提供更好的抽象。
                對創(chuàng)建類的抽象接口的指導(dǎo)建議:
               (1)類的接口應(yīng)該展現(xiàn)一致的抽象層次:在考慮類的時候有一種很好的方法,就是把類安坐一種用來實現(xiàn)ADT的機制。每個類應(yīng)該實現(xiàn)一個ADT,并且僅實現(xiàn)這個ADT,如果你發(fā)現(xiàn)某個類實現(xiàn)了不止一個ADT,或者你不能確定究竟它實現(xiàn)了何種ADT,就應(yīng)該把這個類重新組織為了一個或多個更加明確的ADT。
               (2)一定要理解類所實現(xiàn)的抽象是什么。
               (3)提供成對的服務(wù):大多數(shù)操作都有和其對應(yīng)的、相等的以及相反的操作,如果有一個操作用來把燈打開,那么很可能也需要另一個操作來把燈關(guān)閉。在設(shè)計一個類的時候,要檢查每一個公用子程序,決定是否需要另一個與其互補的操作。不要盲目的創(chuàng)建相反操作,一定要考慮,看看是否需要它。
               (4)盡可能讓接口可編程,而不是表達語義:每個接口都有一個可編程的部分和一個語義部分組成,可編程的部分由接口中的數(shù)據(jù)類型和其他屬性構(gòu)成,編譯器能強制性的在編譯時檢查錯誤,而語義部分則是由“本接口將會被怎樣使用”的假定組成,而這些是如法通過編譯器來強制實施的。
               (5)謹防在修改時破壞接口的抽象性。
               (6)不要添加與接口抽象不一致的公用成員:每次向類添加子程序時,問問“這個子程序與現(xiàn)有接口所提供的抽象一直嗎?”如果發(fā)現(xiàn)不一致,就要換另一種方法來進行修改,以便能夠保持抽象的完整性。
               (7)同時考慮抽象性和內(nèi)聚性:一個呈現(xiàn)出很好的抽象的類接口通常也有很高的內(nèi)聚性【如果一個類表現(xiàn)出很好的抽象性,那么接口一定是朝著一致的方向努力的,從而會具有很好的內(nèi)聚性】。而具有很強的內(nèi)聚性的類往往也會呈現(xiàn)為很好的抽象,但是關(guān)系不如前者強烈。一般關(guān)注類的抽象性比關(guān)注類的內(nèi)聚性更有助于理解類的設(shè)計。 
               封裝是一個比抽象更強的概念,抽象通過提供可以讓你忽略實現(xiàn)細節(jié)的模型來管理復(fù)雜度,而封裝則強制阻止你看到細節(jié)。抽象和封裝是緊密相關(guān)的,沒有封裝,則抽象就容易被打破。一般而言,要么封裝與抽象兩者皆有,要么就是兩者皆失。
               (1)盡可能的限制類和成員的可訪問性:讓可訪問性盡可能低是促成封裝的原則之一。
               (2)不要公開暴露成員數(shù)據(jù):暴露成員數(shù)據(jù)會破壞封裝性,從而限制你對這個抽象的控制能力。【如果暴露了成員數(shù)據(jù),就不知道何時數(shù)據(jù)被修改了】
               (3)避免把私用的實現(xiàn)細節(jié)放入類的接口中。
               (4)不要對類的使用者做出任何假設(shè):類的設(shè)計和實現(xiàn)應(yīng)該符合在類的接口中所隱含的契約。不應(yīng)該對接口會被如果使用或不會被如何使用做出任何假設(shè)。
               (5)避免使用友元類:一般情況下,友元類會破壞封裝,因為它讓你在同一時刻需要考慮更多的代碼量,從而增加復(fù)雜度。
               (6)不要因為一個子程序里僅使用了公用子程序,就把它歸入公開接口:一個子程序僅僅使用公用的子程序這一事實并不是十分重要的考慮因素。相反,應(yīng)該問的問題是,把這個子程序暴露給外界后,接口所展示的抽象是否還是一致的。
               (7)讓閱讀代碼比編寫代碼更方便:閱讀代碼的次數(shù)要比編寫代碼的次數(shù)多的多,即使在開發(fā)的初期。
               (8)要警惕從語義上破壞封裝性:每當(dāng)你發(fā)現(xiàn)自己是通過查看那類的內(nèi)部實現(xiàn)來得知如何使用這個類的時候,你就不是在針對接口編程了,而是在透過接口針對內(nèi)部實現(xiàn)編程了,如果你透過接口來編程的話,封裝性就被破壞了,而一旦封裝性開始遭到破壞,抽象能力就快遭殃了。
               (9)留意過于緊密的耦合關(guān)系。
               耦合性與抽象和封裝性有著非常緊密的聯(lián)系,緊密的額耦合性是發(fā)生在抽象不嚴禁或者封裝性遭到破壞的時候,如一個類提供了一套不完整的服務(wù),其他的子程序就可能要去直接讀寫該類的內(nèi)部數(shù)據(jù),這樣一來,就把類給拆開了,把他從一個黑合盒子變成了一個玻璃合資,從而事實上消除了類的封裝性。
            posted on 2007-09-26 09:16 探丫頭 閱讀(977) 評論(3)  編輯 收藏 引用 所屬分類: 《代碼大全》讀書筆記

            評論:
            # re: 第6章 可以工作的類(2) 2007-09-26 17:18 | 夢在天涯
            都是有點抽象的!

            偶爾來個實例也不錯的餓!  回復(fù)  更多評論
              
            # re: 第6章 可以工作的類(2) 2007-09-27 09:16 | 探丫頭
            呵呵,理論懂了,實例自然就會寫了  回復(fù)  更多評論
              
            # re: 第6章 可以工作的類(2) 2007-09-30 23:00 | Minidx全文檢索
            恩,抽象出來的理論比較具有指導(dǎo)性
            實例只不過是抽象的一種實現(xiàn)方式  回復(fù)  更多評論
              
            久久这里有精品视频| 久久偷看各类wc女厕嘘嘘| 久久久青草久久久青草| 久久91这里精品国产2020| 亚洲AⅤ优女AV综合久久久| 伊人久久久AV老熟妇色| 国产精品久久久久久久久免费 | 久久97久久97精品免视看| 日韩中文久久| 久久福利青草精品资源站免费| 伊人久久综在合线亚洲2019| 中文字幕久久亚洲一区| 久久被窝电影亚洲爽爽爽| 久久久SS麻豆欧美国产日韩| 热久久国产精品| 久久久久久久久久久| 久久99久久成人免费播放| 久久精品亚洲一区二区三区浴池| 久久99久久成人免费播放| 久久久久亚洲Av无码专| 精品国产日韩久久亚洲| 久久国产精品-久久精品| 久久久久亚洲AV无码专区首JN| 91久久国产视频| 久久婷婷国产麻豆91天堂| 亚洲午夜无码久久久久| 久久中文字幕精品| 久久婷婷五月综合成人D啪| 嫩草影院久久国产精品| 成人国内精品久久久久影院| 亚洲日本va中文字幕久久| 久久人人爽人人爽人人片AV高清 | 久久Av无码精品人妻系列| 免费精品久久天干天干| 久久久久无码中| 国产精品成人久久久久久久| 9191精品国产免费久久| 97久久精品人人澡人人爽| 四虎国产精品免费久久5151| 热re99久久精品国产99热| 女人香蕉久久**毛片精品|