• <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>

            平凡的世界

            神鷹忽展翅,頭頂青天飛
            隨筆 - 10, 文章 - 0, 評(píng)論 - 34, 引用 - 0
            數(shù)據(jù)加載中……

            轉(zhuǎn)【規(guī)范化面向?qū)ο筌浖O(shè)計(jì)】

             作為當(dāng)今主流的軟件開發(fā)方法,面向?qū)ο蟪绦蛟O(shè)計(jì)已經(jīng)為廣大程序員所熟悉,什么類呀,繼承呀,多態(tài)呀等等玩意兒也用得嗖嗖的,但是為什么設(shè)計(jì)出來的大多數(shù)系統(tǒng)都很糟糕呢?這里面有兩個(gè)重要原因:一是我們的設(shè)計(jì)師對(duì)面向?qū)ο笤O(shè)計(jì)仍然沒有深刻理解,市面上的很多書也都是些沒什么工程經(jīng)驗(yàn)的“學(xué)院派”專家編寫的,在面向?qū)ο笤O(shè)計(jì)的理論上仍然沒什么完整理論系統(tǒng)出來,有的只是一些零零星星的建議。另一個(gè)原因是目前的面向?qū)ο笳Z言對(duì)面向?qū)ο笤O(shè)計(jì)的支持也不夠完整,尤其是對(duì)關(guān)系的描述。面向?qū)ο笤O(shè)計(jì)的核心思想不是什么什么類呀,繼承呀,多態(tài)呀等概念,甚至完全拋棄這些東西,依然可以設(shè)計(jì)一個(gè)優(yōu)秀的面向?qū)ο蟮能浖到y(tǒng)。面向?qū)ο笤O(shè)計(jì)的核心思想是面向自然的設(shè)計(jì),即通過識(shí)別和表達(dá)出系統(tǒng)中對(duì)象、對(duì)象間的關(guān)系、對(duì)象的狀態(tài)遷移等關(guān)鍵因素,軟件設(shè)計(jì)達(dá)到自然的、正確的描述目標(biāo)系統(tǒng)的目的,這種自然的設(shè)計(jì)忠實(shí)反映了目標(biāo)系統(tǒng)中的對(duì)象和他們之間的關(guān)系以及他們之間的交互過程,是自然系統(tǒng)到軟件系統(tǒng)的自然的映射。任何一個(gè)自然系統(tǒng)都是由一些對(duì)象組成,這些對(duì)象有自己的屬性、行為和事件。任何一個(gè)系統(tǒng)都是不停運(yùn)轉(zhuǎn)的,所以光有對(duì)象還不夠,這些對(duì)象要互動(dòng)起來,才能讓整個(gè)系統(tǒng)運(yùn)轉(zhuǎn),因此這些對(duì)象內(nèi)部的狀態(tài)會(huì)遷移,對(duì)象之間會(huì)有交互,這樣對(duì)象之間就產(chǎn)生了某種關(guān)系。那么究竟有些什么樣的關(guān)系呢?可以把關(guān)系分為三種類型,第一種是組合關(guān)系,也就是HAS-A關(guān)系;第二種是關(guān)聯(lián)關(guān)系,表示對(duì)象間存在某種關(guān)系,如師生關(guān)系、父子關(guān)系等;第三種是認(rèn)識(shí)關(guān)系,表示一個(gè)對(duì)象知道另一個(gè)對(duì)象的一些情況,它可以使用它知道的對(duì)象,比如學(xué)生對(duì)象知道有個(gè)公告板對(duì)象,也知道用它可以貼布告,因此,當(dāng)學(xué)生想發(fā)布告的時(shí)候就使用一下公告板對(duì)象,但學(xué)生對(duì)象并不需要持有一個(gè)公告板對(duì)象,它僅需要知道從哪兒可以得到公告板對(duì)象就行了,這是最弱的一種關(guān)系。有人可能要問了,為什么沒有IS-A關(guān)系呢?那是因?yàn)?/span>IS-A關(guān)系本來就不是自然系統(tǒng)中的關(guān)系,它只是人們?cè)谡J(rèn)識(shí)論中的一個(gè)概念。分類、繼承這些都是認(rèn)識(shí)論的概念,很多設(shè)計(jì)師把它們和自然系統(tǒng)中的對(duì)象、關(guān)系混為一談,隨意的設(shè)計(jì)類、濫用繼承正是當(dāng)今糟糕的所謂的面向?qū)ο蟮能浖a(chǎn)生的根源。規(guī)范化面向?qū)ο筌浖O(shè)計(jì)就是識(shí)別、描述了目標(biāo)系統(tǒng)中所有有效的對(duì)象、對(duì)象狀態(tài)、對(duì)象間關(guān)系、對(duì)象交互過程的設(shè)計(jì),在保證正確反映目標(biāo)系統(tǒng)的前提下,仔細(xì)設(shè)計(jì)類接口,這才是正確的設(shè)計(jì)之道。

            轉(zhuǎn)載同事博客里的一篇文章,好像說的是我,呵呵,臉紅一下。引以為戒。

            posted on 2009-11-03 10:34 西門有悔 閱讀(1669) 評(píng)論(3)  編輯 收藏 引用

            評(píng)論

            # re: 轉(zhuǎn)【規(guī)范化面向?qū)ο筌浖O(shè)計(jì)】  回復(fù)  更多評(píng)論   

            我現(xiàn)在還是將C++當(dāng)C用...也臉紅一個(gè)
            2009-11-03 12:20 | 李佳

            # re: 轉(zhuǎn)【規(guī)范化面向?qū)ο筌浖O(shè)計(jì)】[未登錄]  回復(fù)  更多評(píng)論   

            作者對(duì)面向?qū)ο蟮乃枷肜斫馍羁蹋嫦驅(qū)ο蟛⒉灰欢ㄒ胏++,java,c#寫。c依然可以寫出漂亮的面向?qū)ο髞恚ㄟ@點(diǎn)我從linux源碼中發(fā)現(xiàn),而且它的面向?qū)ο蟪橄蠡臼橇阆牡模枰苌詈竦墓Φ讈硗瓿梢恍┘记桑嫦驅(qū)ο蠛芎美斫猓绦虻谋举|(zhì)還是過程式,所以要把握住對(duì)象構(gòu)造到析構(gòu)的主干線,理解軟件體系中的線程模型。而且對(duì)象的抽象要多加思考,是否真的需要抽象這類對(duì)象,抽象這類對(duì)象是為了什么?能否用聚合組合來替代?過于臃腫的類體系結(jié)構(gòu)擴(kuò)展性受到影響,而且會(huì)增大對(duì)象占用空間,明白什么時(shí)候upcast,什么時(shí)候downcast。好的面向?qū)ο蟪橄笠粯涌梢蕴岣咝剩矣袝r(shí)候用好c++效率還會(huì)比c高(因?yàn)樵谡嬲a執(zhí)行期間,cpu通過ecx知道c++的類對(duì)象上下文),盡量減少或避免虛表重復(fù)查找次數(shù)。面向?qū)ο笫且惶渡钏。暨M(jìn)去一定要出來。
            2009-11-03 13:02 | tiny

            # re: 轉(zhuǎn)【規(guī)范化面向?qū)ο筌浖O(shè)計(jì)】  回復(fù)  更多評(píng)論   

            其實(shí),面相對(duì)像其實(shí)就是在面向過程的,比如C++,許多C++編譯器就是把C++的程序轉(zhuǎn)成C的程序,然后重用C的編譯器。但是,面向?qū)ο裼植皇敲嫦蜻^程的。面向?qū)ο笫且环N思想,就像C能寫出面向?qū)ο蟮某绦騺恚遣灰詾镃++不好,C比較難寫出面向?qū)ο蟮某绦騺恚珻++的目的就是把面向?qū)ο蟮乃枷霊?yīng)用到語言上,讓程序員能在語言上得到支持。
            其實(shí),語言都是其次,重要的還是思想。現(xiàn)在的書很多說的是面向?qū)ο蟮恼Z言,但是還沒有一本很好的書來詮釋面向?qū)ο蟮乃枷搿D茉趹?yīng)用上去解釋面向?qū)ο蟮臅佟OM麌鴥?nèi)能有這么個(gè)人出本這么一本書。
            本人還是個(gè)學(xué)生,不對(duì)的還望包涵。
            2009-11-03 20:03 | chaogu

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


            国产亚洲精久久久久久无码AV| 亚洲国产精品无码久久SM| 国产麻豆精品久久一二三| 久久精品欧美日韩精品| 91超碰碰碰碰久久久久久综合| 久久黄视频| 久久这里只有精品首页| 久久Av无码精品人妻系列 | 亚洲欧洲日产国码无码久久99 | 久久久久国产精品| 国产福利电影一区二区三区久久久久成人精品综合 | 色偷偷888欧美精品久久久| 久久毛片免费看一区二区三区| 久久精品国产亚洲AV久| 成人a毛片久久免费播放| 日韩人妻无码一区二区三区久久99| 99久久久精品| 亚洲国产精品18久久久久久| 久久久久久毛片免费看| 色狠狠久久AV五月综合| 亚洲国产高清精品线久久| 久久精品男人影院| 三上悠亚久久精品| 欧美日韩精品久久久久| 免费一级欧美大片久久网| 亚洲国产成人久久精品影视| 久久综合国产乱子伦精品免费| 四虎影视久久久免费| 久久高清一级毛片| 国内精品久久久久久久coent| 国产精品一久久香蕉国产线看| 亚洲日韩欧美一区久久久久我| 国产免费久久久久久无码| 久久精品免费观看| 996久久国产精品线观看| 2021久久精品国产99国产精品| 狠狠色丁香久久婷婷综合_中| 国产无套内射久久久国产| 狠狠综合久久AV一区二区三区| 7777精品伊人久久久大香线蕉| 久久伊人精品一区二区三区|