青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

隨筆 - 132  文章 - 51  trackbacks - 0
<2011年7月>
262728293012
3456789
10111213141516
17181920212223
24252627282930
31123456

常用鏈接

留言簿(7)

隨筆分類

隨筆檔案

文章分類

文章檔案

cocos2d-x

OGRE

OPenGL

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

游戲中接受到的消息那叫一個多如牛毛啊,這就涉及到switch case接受還是if else接受的效率問題
有人說這是個小問題,哈哈 精益求精嗎

看到了一篇兩者效率比較的文章:


switch...case與if...else的根本區別在于,switch...case會生成一個跳轉表來指示實際的case分支的地址,而這個跳轉表的索引號與switch變量的值是相等的。從而,switch...case不用像if...else那樣遍歷條件分支直到命中條件,而只需訪問對應索引號的表項從而到達定位分支的目的。

具體地說,switch...case會生成一份大小(表項數)為最大case常量+1的跳表,程序首先判斷switch變量是否大于最大case常量,若大于,則跳到default分支處理;否則取得索引號為switch變量大小的跳表項的地址(即跳表的起始地址+表項大小*索引號),程序接著跳到此地址執行,到此完成了分支的跳轉。如下代碼(gcc編譯,不開優化):

int main()
{
    int j = 0;
    int i = 1;

    switch (i)
    {
        case 1:
            j = 11;
            break;
        case 2:
            j = 22;
            break;
        case 3:
            j = 33;
            break;
        case 4:
            j = 44;
            break;
        case 10:
            j = 10;
    
        default:
            j = 88;
            break;
    }

    return 0;
}

這是編譯后的部分匯編碼:

    .file    "test.c"
    .text
.globl main
    .type    main, @function
main:
    leal    4(%esp), %ecx
    andl    $-16, %esp
    pushl    -4(%ecx)
    pushl    %ebp
    movl    %esp, %ebp
    pushl    %ecx
    subl    $16, %esp
    movl    $0, -8(%ebp)
    movl    $1, -12(%ebp)
    cmpl    $10, -12(%ebp)
    ja    .L2
    movl    -12(%ebp), %eax
    sall    $2, %eax
    movl    .L8(%eax), %eax
    jmp    *%eax
    .section    .rodata
    .align 4
    .align 4
.L8:
    .long    .L2
    .long    .L3
    .long    .L4
    .long    .L5
    .long    .L6
    .long    .L2
    .long    .L2
    .long    .L2
    .long    .L2
    .long    .L2
    .long    .L7
    .text
.L3:
    movl    $11, -8(%ebp)
    jmp    .L9
.L4:
    movl    $22, -8(%ebp)
    jmp    .L9
.L5:
    movl    $33, -8(%ebp)
    jmp    .L9
.L6:
    movl    $44, -8(%ebp)
    jmp    .L9
.L7:
    movl    $10, -8(%ebp)
.L2:
    movl    $88, -8(%ebp)
.L9:
    movl    $0, %eax
    addl    $16, %esp
    popl    %ecx
    popl    %ebp
    leal    -4(%ecx), %esp
    ret

可以打個比方,switch...case訪問條件分支的方式像數組一樣,是隨機訪問;而if...else是順序訪問。

他們各自的特點:

1、 總體上說,switch...case 效率要高于同樣條件下的if...else,特別是當條件分支較多時。

2、switch...case占用較多的代碼空間,因為它要生成跳表,特別是當case常量分布范圍很大但實際有效值又比較少的情況,switch...case的空間利用率將變得很低。例如上面的代碼,如果把case 10改成case 100,則會生成101個表項,而大部分表項是指向同一分支(default分支)。switch...case是在以空間換時間。

3、switch...case只能處理case為常量的情況,對非常量的情況是無能為力的。例如 if (a > 1 && a < 100),是無法使用switch...case來處理的。

***注意:如果把例子中的case分支減少一個,則生成的匯編碼與if...else差別不大,此時不會生成跳表項,可見對于分支較少的情況,編譯器會做特殊處理。

原文地址:http://blog.csdn.net/kevinyujm/archive/2009/02/18/3907964.aspx

posted on 2010-12-18 18:41 風輕云淡 閱讀(3365) 評論(6)  編輯 收藏 引用 所屬分類: C++

FeedBack:
# re: 游戲消息效率之switch...case && if...else  2010-12-18 20:46 清正
有趣, 深入到匯編底層了。 還是第一次意識到呢。 不錯!  回復  更多評論
  
# re: 游戲消息效率之switch...case && if...else  2010-12-19 14:05 wildpointer
switch...case的翻譯與case的數目和case的值的范圍有關。
如果case少,那么和if...else...差不多。
如果case較多,分兩種情況
1:case的值較集中,如你的例子,1,2,3,4,10,那么會生成一個表。
2:case的值較分散,編譯器會用二分查找的方式確定執行哪個case。
  回復  更多評論
  
# re: 游戲消息效率之switch...case && if...else  2010-12-20 10:06 曾濤
樓上right,如果就兩個case,0和全f,難道生成4G個條目?

如果不開優化的話switch效率是高一些。  回復  更多評論
  
# re: 游戲消息效率之switch...case && if...else [未登錄] 2010-12-20 17:45 123
跳轉表就不說了,不使用跳轉表的情況下,很多地方的邏輯都適用二八原則,也就是說用IF ELSE把幾率大的選項寫在前面,比自動的二分查找更優  回復  更多評論
  
# re: 游戲消息效率之switch...case && if...else  2010-12-21 15:34 Let me see see
看到一個游戲引擎中接受消息的部分,原來都是用if..else接受處理,在加大到幾百條消息后速度明顯不如switch

不清楚這種情況下編譯器如何給if...else做優化  回復  更多評論
  
# re: 游戲消息效率之switch...case && if...else  2010-12-23 09:45 李現民
switch語句被匯編翻譯的結果與case的長度及數值規律有密切關系,并不是簡單的翻譯成跳轉表, 同時與編譯器的優化能力也有關。

你可以看一下這篇文章:
http://www.shnenglu.com/besterChen/archive/2009/12/07/102682.html  回復  更多評論
  
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
              麻豆视频一区二区| 亚洲淫片在线视频| 欧美凹凸一区二区三区视频| 91久久久久久久久| 亚洲成人在线视频播放| 免费观看亚洲视频大全| 亚洲日韩欧美视频一区| 日韩视频在线免费观看| 国产精品扒开腿爽爽爽视频| 午夜精品久久久久久久蜜桃app | 日韩小视频在线观看专区| 亚洲品质自拍| 国产精品一区二区在线观看网站| 久久激情视频久久| 欧美~级网站不卡| 亚洲性视频网站| 欧美一级黄色网| 亚洲国产精品悠悠久久琪琪| 99精品国产一区二区青青牛奶| 国产精品久久久久9999| 久久中文字幕一区二区三区| 欧美啪啪一区| 久久激情网站| 欧美日韩国产bt| 久久久女女女女999久久| 欧美伦理影院| 久久综合激情| 国产精品久久久久一区| 欧美成人在线影院| 国产精品视频久久| 最近看过的日韩成人| 国产亚洲免费的视频看| 亚洲狠狠婷婷| 伊人蜜桃色噜噜激情综合| 日韩午夜电影在线观看| 亚洲国产aⅴ天堂久久| 亚洲欧美日本另类| 一本综合久久| 另类综合日韩欧美亚洲| 欧美一区国产一区| 欧美午夜剧场| 国产精品网红福利| 久久国产乱子精品免费女| 欧美精品尤物在线| 久久综合给合久久狠狠狠97色69| 欧美性天天影院| 亚洲黄色在线观看| 亚洲黄一区二区三区| 久久国产精品网站| 久久国产日韩欧美| 国产精品久久网站| 在线视频日韩精品| 中文在线资源观看网站视频免费不卡| 米奇777在线欧美播放| 噜噜噜久久亚洲精品国产品小说| 国产精品国产三级国产普通话99| 亚洲欧洲一二三| 亚洲精品小视频| 欧美不卡视频| 亚洲日韩中文字幕在线播放| 亚洲人体大胆视频| 免费观看在线综合色| 欧美成人精品一区| 亚洲欧洲日本专区| 欧美大片免费观看在线观看网站推荐| 欧美成人首页| 亚洲精品在线视频| 欧美日韩国产二区| 一个人看的www久久| 亚洲综合色噜噜狠狠| 欧美天天视频| 亚洲一区国产精品| 久久久九九九九| 在线国产精品播放| 欧美成人精品影院| 日韩一区二区久久| 欧美一区二区在线视频| 激情欧美日韩| 男女激情视频一区| 99国产精品视频免费观看| 亚洲综合激情| 黄色日韩精品| 欧美成人精品在线| 一区二区三区日韩| 久久精品国产视频| 亚洲国产一区二区在线| 欧美日韩高清在线一区| 亚洲无线视频| 老鸭窝毛片一区二区三区| 亚洲乱码国产乱码精品精天堂| 欧美日韩精品免费| 欧美一区二区三区四区在线| 欧美激情aⅴ一区二区三区| 国产精品99久久久久久人| 国产日韩欧美中文在线播放| 麻豆精品91| 亚洲欧美区自拍先锋| 欧美成人高清| 亚洲欧美一区二区视频| 在线欧美不卡| 国产精品美女久久久久aⅴ国产馆| 久久不见久久见免费视频1| 亚洲精品视频一区二区三区| 欧美一区二区三区男人的天堂| 亚洲国产精品电影| 国产毛片久久| 欧美日本亚洲韩国国产| 久久久久国产精品麻豆ai换脸| 亚洲精品男同| 欧美第十八页| 久久久久九九九九| 亚洲一区二区三区乱码aⅴ| 久久久久国产一区二区| 久久精品国产亚洲aⅴ| 亚洲国产日韩在线一区模特| 国产欧美日韩亚洲| 欧美绝品在线观看成人午夜影视| 久久精品国产亚洲5555| 亚洲视屏一区| 9i看片成人免费高清| 欧美黄免费看| 美国三级日本三级久久99| 欧美一区二区三区免费观看| 亚洲视频综合在线| 亚洲日本电影在线| 在线观看91久久久久久| 国产婷婷色一区二区三区四区| 欧美日韩一区二区三区四区在线观看 | 午夜在线精品| 在线亚洲电影| 日韩网站在线看片你懂的| 亚洲国产综合在线| 免费日韩一区二区| 久久亚洲综合色一区二区三区| 欧美亚洲日本网站| 亚洲欧美影音先锋| 亚洲欧美国内爽妇网| 亚洲影院在线观看| 亚洲免费视频网站| 午夜精品婷婷| 欧美一区二区免费观在线| 香蕉精品999视频一区二区| 亚洲女人天堂av| 亚洲欧美日韩国产一区二区三区| 亚洲一区二区在线观看视频| 亚洲一区二区三区国产| 亚洲综合国产| 久久国产精品72免费观看| 久久精品五月| 女人天堂亚洲aⅴ在线观看| 欧美激情片在线观看| 亚洲国产一区二区在线| 亚洲美女区一区| 一区二区高清视频| 亚洲欧美日韩在线观看a三区| 亚洲欧美日韩精品综合在线观看| 亚洲欧美日韩另类精品一区二区三区 | 亚洲精品在线观| 中文国产一区| 性亚洲最疯狂xxxx高清| 久久九九99视频| 欧美成人一区二免费视频软件| 欧美国产一区二区在线观看| 亚洲人成久久| 午夜国产欧美理论在线播放| 欧美一区亚洲| 欧美成人一区二免费视频软件| 欧美日韩一二三区| 国产一区清纯| 99国产一区二区三精品乱码| 午夜国产欧美理论在线播放 | 亚洲无毛电影| 久久精品一区二区国产| 亚洲国内在线| 欧美一区二区精品| 欧美激情片在线观看| 国产美女精品免费电影| 亚洲国产另类久久精品| 亚洲免费在线观看| 欧美+亚洲+精品+三区| 在线视频你懂得一区| 久久久999精品| 欧美日韩一区二区三区| 亚洲小说欧美另类婷婷| 亚洲国产精品激情在线观看| 亚洲日韩中文字幕在线播放| 亚洲欧美日韩另类| 欧美激情在线有限公司| 国产有码在线一区二区视频| 一个色综合av| 欧美激情视频给我| 欧美亚洲一区二区在线| 欧美日韩精品福利| 亚洲国产乱码最新视频| 久久精品国产99| 亚洲午夜视频在线观看| 欧美日本国产一区| 亚洲国产高清视频| 久久天天躁夜夜躁狠狠躁2022| 一个色综合av|