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

            Zero Lee的專欄

            組件間的物理關系

            ???開發可維護、易測試和可重用的軟件需要全面的物理設計和邏輯設計的知識。物理設計研究組織的問題,超出了邏輯領域的范疇,物理設計很容易影響可測量的特性,例如運行時間、編譯時間、連接時間以及可執行文件大小。

            ???一個組件是由一個.c文件和.h文件組成的物理實體,它具體表達了一個邏輯抽象的具體實現。一個組件一般包含一個、兩個甚至多個類,已經需要用來支持全部抽象的適當的自由運算符。一個組件(而不是一個類)是邏輯設計和物理設計的適當單位,因為它能夠:
            ???1)讓若干邏輯實體把一個單一的抽象表現為一個內聚單位;
            ???2)考慮到物理問題和組織問題;
            ?? 3)在其他程序中選擇性地重用編譯單元。

            ???一個組件的邏輯接口僅限于指能夠被客戶程序通過編譯訪問的部分,而物理接口則包括它的整個頭文件。如果在一個組件的物理接口中使用了一個用戶自定義類型T,即使T是一個封裝的邏輯細節,也可能迫使那個組件的客戶程序在編譯時依賴T的定義。
            ???組件是自我包含的、內聚的和潛在的可重用的設計單位。在一個組件內部聲明的邏輯結構不應該定義在那個組件之外。一個組件的.c文件應該直接包含它的.h文件,以確保.h文件可基于它自己進行語法分析。對于每一個需要的類型定義,都始終包含其頭文件,而不是依賴一個頭文件去包含另一個,這樣,當一個組件允許一個#include 指令從其頭文件中被刪除時不會出現問題。想要改進可用性、可重用性和可維護性,如果某個帶有外部連接的結構沒有在一個組件的.h文件聲明,那么我們應該避免把該結構放在這個組件的.c文件中。同樣的原因,我們應該避免使用局部聲明去訪問有外部連接的定義。
            ???
            ???最后友元關系雖然表面上是一個邏輯關系,但會影響到物理設計。在一個組件內部,(局部的)友元關系是那個組件的一個封裝的實現細節。為了改進可用性和用戶可擴展性,一個容器類常常會把同一個組件內的迭代器視作友元,不會破壞封裝。友元關系只會直接影響訪問權限但不會隱含依賴。

            posted on 2007-03-20 20:56 Zero Lee 閱讀(854) 評論(2)  編輯 收藏 引用 所屬分類: CC++ Programming

            評論

            # re: 組件間的物理關系 2007-03-21 10:03 Neal

            寫的不錯,不過有一點覺得不妥。
            “組件”不知是不是指component呢?
            個人認為,不能簡單的把C文件和組件對應起來;C/C++的文件組織不象JAVA之類的語言,要求遵循一定的規則,C/C++的文件組織是很散漫的。不過作為一種coding standard,強制要求把組件和文件對應起來也未嘗不可,但這實際上會降低組件的可維護性和代碼級別的重用性。  回復  更多評論   

            # re: 組件間的物理關系 2007-03-21 10:20 kkk

            你想說的是減少編譯依賴性,有個基本原則:能不知道的就不要知道。比如類的成員是個指針,就不要在。h中包含定義那個類的。h文件,用個前導申明。  回復  更多評論   

            精品伊人久久大线蕉色首页| 久久久久亚洲AV无码专区首JN| 99久久这里只精品国产免费| 伊人久久大香线焦AV综合影院| 亚洲精品高清久久| 亚洲欧美成人综合久久久 | 久久棈精品久久久久久噜噜| 精品久久久久久国产免费了| 精品国产乱码久久久久久郑州公司| 色综合久久中文字幕综合网| 91秦先生久久久久久久| 亚洲一级Av无码毛片久久精品| a级毛片无码兔费真人久久 | 久久伊人精品青青草原高清| 7777精品久久久大香线蕉| 国产欧美久久一区二区| 久久精品国产精品亚洲毛片 | 国产高潮久久免费观看| 精品久久人人爽天天玩人人妻| 国产精品无码久久久久| 久久久久人妻精品一区| 无码任你躁久久久久久老妇App| 久久久久一区二区三区| 久久香蕉国产线看观看精品yw | 精品无码久久久久久午夜| 最新久久免费视频| 久久天天躁狠狠躁夜夜av浪潮 | 国产精品久久久久久久午夜片| 久久久精品人妻一区二区三区四 | 久久久女人与动物群交毛片| 久久精品视频一| 亚洲av日韩精品久久久久久a| 久久久久久青草大香综合精品| 久久久这里只有精品加勒比| 久久久久国产一级毛片高清板 | 丰满少妇人妻久久久久久| 亚洲国产欧美国产综合久久| 久久久无码精品亚洲日韩蜜臀浪潮| 久久久久久久综合综合狠狠| 青春久久| 精品久久亚洲中文无码|