• <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++中的類成員函數(shù)沒有采用類似Java中的“全虛”設(shè)計

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

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

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

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

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

            在內(nèi)核不能分頁(paging)時必須保證將被執(zhí)行的所有代碼和數(shù)據(jù)必須有效的駐留在物理內(nèi)存中,如果這時需要多駐留幾張?zhí)摫硪约疤摫碇羔樐沁€是顯得非常昂貴的,同時編譯器為虛函數(shù),模板等生成代碼的方式,讓開發(fā)人員很難確定要執(zhí)行一個函數(shù)所需要的所有代碼的所在位置,因此也無法直接控制用于安置這些代碼的節(jié)(個人認為可能通過progma segment/datasegment/codesegment對于代碼和數(shù)據(jù)進行集中控制),因此在需要這些代碼時,可能已經(jīng)被page out了;

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

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

            評論

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

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

            <2025年6月>
            25262728293031
            1234567
            891011121314
            15161718192021
            22232425262728
            293012345

            導航

            統(tǒng)計

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            色噜噜狠狠先锋影音久久| 污污内射久久一区二区欧美日韩| 伊人 久久 精品| 久久人人爽人人人人片av| 日韩精品久久无码人妻中文字幕| 人妻久久久一区二区三区| 精品久久久久久亚洲| 久久91这里精品国产2020| 77777亚洲午夜久久多喷| 精品蜜臀久久久久99网站| 久久久久无码专区亚洲av| 四虎国产精品成人免费久久| 国产精品美女久久久| 久久亚洲高清综合| 四虎国产永久免费久久| 亚洲精品白浆高清久久久久久 | 一级A毛片免费观看久久精品| 亚洲а∨天堂久久精品| 欧美777精品久久久久网| 97精品伊人久久大香线蕉| 久久久综合九色合综国产| 久久九九久精品国产免费直播| 久久精品国产精品青草app| 亚洲精品无码久久毛片| 精品国产一区二区三区久久蜜臀| 久久精品日日躁夜夜躁欧美| 欧洲国产伦久久久久久久| 青青草原综合久久大伊人精品| 亚洲午夜久久久久妓女影院| 亚洲国产成人精品女人久久久 | 久久91这里精品国产2020| 久久久亚洲欧洲日产国码aⅴ | 色综合久久无码五十路人妻 | 久久久无码精品亚洲日韩蜜臀浪潮 | 国产69精品久久久久观看软件 | 久久久精品人妻一区二区三区四| 99久久久久| 久久精品中文字幕有码| 亚洲狠狠久久综合一区77777| 99久久精品毛片免费播放| 成人资源影音先锋久久资源网|