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

            Bugs

            MMORPG game develop.

            [引用]More Effective C++ 條款15


            條款15:了解異常處理的系統(tǒng)開銷


            為了在運行時處理異常,程序要記錄大量的信息。無論執(zhí)行到什么地方,程序都必須能夠識別出如果在此處拋出異常的話,將要被釋放哪一個對象;程序必須知道每一個入口點,以便從try塊中退出;對于每一個try塊,他們都必須跟蹤與其相關(guān)的catch子句以及這些catch子句能夠捕獲的異常類型。這種信息的記錄不是沒有代價的。確保程序滿足異常規(guī)格不需要運行時的比較(runtime comparisons),而且當異常被拋出時也不用額外的開銷來釋放相關(guān)的對象和匹配正確的catch字句。但是異常處理確是有代價的,即使你沒有使用try,throw或catch關(guān)鍵字,你同樣得付出一些代價。


            讓我們先從你不使用任何異常處理特性也要付出的代價談起。你需要空間建立數(shù)據(jù)結(jié)構(gòu)來跟蹤對象是否被完全構(gòu)造(constructed)(參加條款10),你也需要系統(tǒng)時間保持這些數(shù)據(jù)結(jié)構(gòu)不斷更新。這些開銷一般不是很大,但是當采用不支持異常的方法編譯的程序一般比支持異常的程序運行速度更快所占空間也更小。


            在理論上,你不能對此進行選擇:C++編譯器必須支持異常,也就是說,當你不用異常處理時你不能讓編譯器生產(chǎn)商消除這方面的開銷,因為程序一般由多個獨立生成的目標文件(object files)組成,只有一個目標文件不進行異常處理并不能代表其他目標文件不進行異常處理。而且即使組成可執(zhí)行文件的目標文件都不進行異常處理,那么還有它們所連接的程序庫呢?如果程序的任何部分使用了異常,其它部分必須也支持異常。否則在運行時程序就不可能提供正確的異常處理。


            不過這只是理論,實際上大部分支持異常的編譯器生產(chǎn)商都允許你自由控制是否在生成的代碼里包含進支持異常的內(nèi)容。如果你知道你程序的任何部分都不使用try,throw或catch,并且你也知道所連接的程序庫也沒有使用try,throw或catch,你就可以采用不支持異常處理的方法進行編譯,這可以縮小程序的尺寸和提高速度,否則你就得為一個不需要的特性而付出代價。隨著時間的推移,使用異處理的程序庫開始變得普遍了,上面這種方法將逐漸不能使用,但是根據(jù)目前的軟件開發(fā)情況來看,如果你已經(jīng)決定不使用任何的異常特性,那么采用不支持異常的方法編譯程序是一個性能優(yōu)化的合理方法。同樣這對于想避開異常的程序庫來說也是一個性能優(yōu)化的好方法,這能保證異常不會從客戶端程序傳遞進程序庫里,不過同時這樣做也會妨礙客戶端程序重定義程序庫中聲明的虛擬函數(shù),并不允許有在客戶端定義的回調(diào)函數(shù)。


            使用異常處理的第二個開銷來自于try塊,無論何時使用它,也就是無論何時你想能夠捕獲異常,那你都得為此付出代價。不同的編譯器實現(xiàn)try塊的方法不同,所以編譯器與編譯器間的開銷也不一樣。粗略地估計,如果你使用try塊,代碼的尺寸將增加5%-10%并且運行速度也同比例減慢。這還是假設(shè)程序沒有拋出異常,我這里討論的只是在程序里使用try塊的開銷。為了減少開銷,你應(yīng)該避免使用無用的try塊。


            編譯器為異常規(guī)格生成的代碼與它們?yōu)?span>try塊生成的代碼一樣多,所以一個異常規(guī)格一般花掉與try塊一樣多的系統(tǒng)開銷。什么?你說你認為異常規(guī)格只是一個規(guī)格而已,你認為它們不會產(chǎn)生代碼?那么好,現(xiàn)在你應(yīng)該對此有新的認識了。


            現(xiàn)在我們來到了問題的核心部分,看看拋出異常的開銷。事實上我們不用太關(guān)心這個問題,因為異常是很少見的,這種事件的發(fā)生往往被描述為exceptional(異常的,罕見的)。80-20規(guī)則(參見條款16)告訴我們這樣的事件不會對整個程序的性能造成太大的影響。但是我知道你仍舊好奇地想知道如果拋出一個異常到底會有多大的開銷,答案是這可能會比較大。與一個正常的函數(shù)返回相比,通過拋出異常從函數(shù)里返回可能會慢三個數(shù)量級。這個開銷很大。但是僅僅當你拋出異常時才會有這個開銷,一般不會發(fā)生。但是如果你用異常表示一個比較普遍的狀況,例如完成對數(shù)據(jù)結(jié)構(gòu)的遍歷或結(jié)束一個循環(huán),那你必須重新予以考慮。

            posted on 2008-03-27 17:06 Bugs 閱讀(1007) 評論(4)  編輯 收藏 引用

            評論

            # re: [引用]More Effective C++ 條款15 2008-03-27 17:14 Bugs

            我自己對異常處理的心得有下列幾點,僅供參考,希望大家說說各自的意見。
            1.盡量避免使用異常處理,能不能則不用,可以用C Style的Error處理方式來代替。(對于渴望性能很實用)
            2.即使要使用,也一定把Scope降到最低,盡量減少多重嵌套。
            3.如果整個生產(chǎn)系統(tǒng)使用了不穩(wěn)定的第三方庫,建議使用異常處理,畢竟服務(wù)器穩(wěn)定勝于性能。  回復(fù)  更多評論   

            # re: [引用]More Effective C++ 條款15 2008-03-31 22:41 Fox

            對異常處理沒有特別關(guān)注過,搬著板凳先看到  回復(fù)  更多評論   

            # re: [引用]More Effective C++ 條款15 2008-04-01 15:11 酷勤網(wǎng)

            哪里有這本書的網(wǎng)上譯文?  回復(fù)  更多評論   

            # re: [引用]More Effective C++ 條款15 2008-04-03 13:58 Bugs

            不知道,你去找找吧  回復(fù)  更多評論   


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


            久久久老熟女一区二区三区| 亚洲国产欧洲综合997久久| 国产精品欧美久久久天天影视| 久久国产精品99久久久久久老狼| 99久久国产亚洲高清观看2024| 久久一区二区免费播放| 久久99精品国产麻豆 | 久久影视国产亚洲| 亚洲综合伊人久久综合| 国产福利电影一区二区三区,免费久久久久久久精 | 99久久99久久久精品齐齐 | 久久精品亚洲精品国产欧美| 久久久久亚洲Av无码专| 伊人色综合久久天天人守人婷| 精品久久一区二区| 亚洲欧美成人综合久久久| 久久精品三级视频| 久久综合久久综合九色| 久久婷婷五月综合色高清| 色综合合久久天天给综看| 久久久综合九色合综国产| 无码国内精品久久人妻| 久久久久久国产a免费观看黄色大片| 国产精品久久久久9999| 久久男人Av资源网站无码软件 | 久久久精品视频免费观看| 91精品国产91久久久久久蜜臀| 精品蜜臀久久久久99网站| 久久婷婷国产综合精品 | 欧美精品一本久久男人的天堂| 亚洲国产精品无码久久久蜜芽| 亚洲乱码日产精品a级毛片久久| 嫩草影院久久国产精品| 亚洲AV无一区二区三区久久| 日日狠狠久久偷偷色综合免费| 99久久精品国产一区二区三区| 91精品国产高清久久久久久io| 久久精品人成免费| 久久精品国产久精国产思思| 久久精品亚洲精品国产色婷 | 久久久久无码精品国产app|