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

            為何C++中的類成員函數沒有采用類似Java中的“全虛”設計

            關于程序設計語言本身的設計有許多有趣的話題,比如,為何C++中的類成員函數沒有采用類似Java中的“全虛”設計?

            1) 從語言本身設計上看,
            效率定然是c++當初設計時考慮的重點之一,舉個例子,為了節省不必要的VTable開銷,ATL用template技術靜態轉換來模擬動態綁定以支持COM特性的實現;和C的兼容,就VTable角度看,問題不大,因為后者可以用函數指針數組來模擬;

            2) 再從大多數應用中常見的類繼承體系上看,
            除了整個繼承體系所統一開放出來的接口集(也就是由虛函數所組成),在繼承體系的每個層面另外會有大量的其他輔助成員函數(其數量通常比虛函數多的多),這些成員函數完全沒必要設計成虛函數;

            3) 從其他語言看,
            即使較新的虛擬機語言C#(Java算是較老的虛擬機語言),反而定義了比C++更為嚴格更為顯式的成員方法實現或覆蓋或重載或新建的規則;這是非常重要的對C++以及Java設計思想的反思。

            4) 從語言的適用場合看,
            我們現在的討論,絕大多數情況下帶有一個非常重要的默認前提,那就是在用戶態模式下使用C++,如果放寬這個約束,在內核模式下使用C++,那情況又完全不同了。
            引用下面這個文檔的觀點,http://www.microsoft.com/china/whdc/driver/kernel/KMcode.mspx
            首先,用戶態下非常廉價幾乎不用考慮的資源,在內核中是非常昂貴的,比如內核堆棧一般就3個page;

            在內核不能分頁(paging)時必須保證將被執行的所有代碼和數據必須有效的駐留在物理內存中,如果這時需要多駐留幾張虛表以及虛表指針那還是顯得非常昂貴的,同時編譯器為虛函數,模板等生成代碼的方式,讓開發人員很難確定要執行一個函數所需要的所有代碼的所在位置,因此也無法直接控制用于安置這些代碼的節(個人認為可能通過progma segment/datasegment/codesegment對于代碼和數據進行集中控制),因此在需要這些代碼時,可能已經被page out了;

            所有涉及類層次結構,模板,異常等等這樣的一些語言結構在內核態中都可能是不安全的,最好是把類的使用限定為POD類,回到我們的主題虛函數,也就是說內核態下類設計中沒有虛函數。

            posted on 2010-12-13 08:57 flagman 閱讀(1696) 評論(1)  編輯 收藏 引用 所屬分類: 設計 Design 、C++ 、思考和學習 Thinking & Learning

            評論

            # re: 為何C++中的類成員函數沒有采用類似Java中的“全虛”設計 2010-12-13 10:41 空明流轉

            模板可以認為是安全的。  回復  更多評論   

            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            導航

            統計

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            欧美久久精品一级c片片| 精品久久久噜噜噜久久久 | 久久99热这里只频精品6| 青春久久| 久久亚洲精品视频| 久久久无码精品亚洲日韩蜜臀浪潮| 亚洲精品乱码久久久久久蜜桃不卡 | 久久超碰97人人做人人爱| 欧美伊香蕉久久综合类网站| 一本久道久久综合狠狠躁AV| 无码人妻久久久一区二区三区| 欧美777精品久久久久网| 国产精品亚洲综合久久| 久久99精品九九九久久婷婷 | 欧美丰满熟妇BBB久久久| 狠狠色综合久久久久尤物| 久久精品一本到99热免费| 日日狠狠久久偷偷色综合免费| 国产亚洲色婷婷久久99精品| 狠狠色丁香婷婷久久综合五月| 狠狠人妻久久久久久综合蜜桃| 日日躁夜夜躁狠狠久久AV| 天天影视色香欲综合久久| 国产高清国内精品福利99久久| 东京热TOKYO综合久久精品| 久久天天婷婷五月俺也去| 99久久精品免费看国产| 久久伊人精品青青草原高清| 亚洲va久久久噜噜噜久久天堂| 婷婷久久香蕉五月综合加勒比| 亚洲а∨天堂久久精品9966| 久久青草国产手机看片福利盒子| 久久久精品人妻一区二区三区四| 亚洲精品白浆高清久久久久久| 午夜精品久久影院蜜桃| 久久99久久无码毛片一区二区| 久久综合狠狠综合久久激情 | 国产成人精品久久一区二区三区 | 伊人久久大香线蕉影院95| 九九久久99综合一区二区| 秋霞久久国产精品电影院|