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

            評(píng)論:
            # re: 第6章 可以工作的類(lèi)(2) 2007-09-26 17:18 | 夢(mèng)在天涯
            都是有點(diǎn)抽象的!

            偶爾來(lái)個(gè)實(shí)例也不錯(cuò)的餓!  回復(fù)  更多評(píng)論
              
            # re: 第6章 可以工作的類(lèi)(2) 2007-09-27 09:16 | 探丫頭
            呵呵,理論懂了,實(shí)例自然就會(huì)寫(xiě)了  回復(fù)  更多評(píng)論
              
            # re: 第6章 可以工作的類(lèi)(2) 2007-09-30 23:00 | Minidx全文檢索
            恩,抽象出來(lái)的理論比較具有指導(dǎo)性
            實(shí)例只不過(guò)是抽象的一種實(shí)現(xiàn)方式  回復(fù)  更多評(píng)論
              
            国产高潮国产高潮久久久91| 成人午夜精品久久久久久久小说| 久久e热在这里只有国产中文精品99 | 久久91精品久久91综合| 久久91精品国产91久久户| 精品久久久久久无码中文字幕| 精品久久人人做人人爽综合| 久久精品国产亚洲AV影院| 国产午夜精品久久久久免费视| 午夜不卡888久久| 国内精品久久久久影院薰衣草 | 日本强好片久久久久久AAA| 久久久青草青青亚洲国产免观| 久久一区二区免费播放| 国产精品一区二区久久国产| 一97日本道伊人久久综合影院| 久久99精品久久久久久hb无码| 久久久精品无码专区不卡| 久久精品国产亚洲av麻豆小说 | 久久发布国产伦子伦精品| 久久精品亚洲精品国产欧美| 久久天天躁狠狠躁夜夜躁2O2O| 久久夜色撩人精品国产| 日韩亚洲欧美久久久www综合网| 亚洲中文久久精品无码ww16| 久久青青国产| 久久精品国产一区二区| 亚洲国产成人久久综合碰碰动漫3d| 麻豆av久久av盛宴av| 久久亚洲av无码精品浪潮| 日本精品久久久中文字幕| 国内精品人妻无码久久久影院| 久久丫忘忧草产品| 久久人人青草97香蕉| 伊人久久精品影院| 色天使久久综合网天天| 久久久久无码精品| 久久成人国产精品一区二区| 伊人丁香狠狠色综合久久| 成人国内精品久久久久影院VR| 国内精品久久国产大陆|