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

            woaidongmao

            文章均收錄自他人博客,但不喜標題前加-[轉貼],因其丑陋,見諒!~
            隨筆 - 1469, 文章 - 0, 評論 - 661, 引用 - 0
            數據加載中……

            if和switch效率的再研究

            昨天發現了一本叫做CSAPP的書,終于找到了關于switch問題的解答。
            這是一段C代碼:


            GCC匯編出來的代碼如下:

            CODE:

                .file    "switch.c"
                .version    "01.01"
            gcc2_compiled.:
            .text
                .align 4
            .globl switch_eg
                .type     switch_eg,@function
            switch_eg:
                pushl %ebp
                movl %esp,%ebp
                movl 8(%ebp),%edx
                leal -100(%edx),%eax
                cmpl ,%eax
                ja .L9
                jmp *.L10(,%eax,4)
                .p2align 4,,7
            .section    .rodata
                .align 4
                .align 4
            .L10:
                .long .L4
                .long .L9
                .long .L5
                .long .L6
                .long .L8
                .long .L9
                .long .L8
            .text
                .p2align 4,,7
            .L4:
                leal (%edx,%edx,2),%eax
                leal (%edx,%eax,4),%edx
                jmp .L3
                .p2align 4,,7
            .L5:
                addl ,%edx
            .L6:
                addl ,%edx
                jmp .L3
                .p2align 4,,7
            .L8:
                imull %edx,%edx
                jmp .L3
                .p2align 4,,7
            .L9:
                xorl %edx,%edx
            .L3:
                movl %edx,%eax
                movl %ebp,%esp
                popl %ebp
                ret
            .Lfe1:
                .size     switch_eg,.Lfe1-switch_eg
                .ident    "GCC: (GNU) 2.95.3 20010315 (release)"
            在上面的匯編代碼中我們可以很清楚的看到switch部分被分配了一個連續的查找表,switch case中不連續的部分也被添加上了相應的條目,switch表的大小不是根據case語句的多少,而是case的最大值的最小值之間的間距。在選擇相應 的分支時,會先有一個cmp子句,如果大于查找表的最大值,則跳轉到default子句。而其他所有的case語句的耗時都回事O(1)。

            相比于if-else結構,switch的效率絕對是要高很多的,但是switch使用查找表的方式決定了case的條件必須是一個連續的常量。而if-else則可以靈活的多。

            posted on 2008-12-17 16:47 肥仔 閱讀(1074) 評論(1)  編輯 收藏 引用 所屬分類: C++ 基礎

            評論

            # re: if和switch效率的再研究[未登錄]  回復  更多評論   

            標準中沒有規定怎么處理,因此具體結果依賴于不同的編譯器。
            2008-12-17 20:13 | Chipset
            亚洲色欲久久久综合网| 9久久9久久精品| 伊人久久大香线蕉无码麻豆| 亚洲午夜精品久久久久久浪潮 | 亚洲性久久久影院| 久久久亚洲精品蜜桃臀| 久久国产精品一国产精品金尊| 久久久久久狠狠丁香| 久久精品成人免费观看97| 人妻无码αv中文字幕久久| 蜜桃麻豆www久久国产精品| 色88久久久久高潮综合影院| 热re99久久精品国产99热| 欧美亚洲国产精品久久| 日韩欧美亚洲国产精品字幕久久久 | 思思久久99热只有频精品66| 国产福利电影一区二区三区,免费久久久久久久精 | 久久久久亚洲国产| 欧美亚洲另类久久综合| 久久久久久精品成人免费图片| 品成人欧美大片久久国产欧美...| 久久久亚洲精品蜜桃臀| 亚洲午夜久久久久久久久电影网 | 亚洲国产一成久久精品国产成人综合 | 国产精品日韩欧美久久综合| 99久久国产宗和精品1上映| 欧美精品一区二区久久| 97久久精品人人澡人人爽| 国产成人久久久精品二区三区| 人妻无码中文久久久久专区| 亚洲人成电影网站久久| 久久久久国产精品麻豆AR影院| 久久超乳爆乳中文字幕| 国内高清久久久久久| 亚洲欧洲久久av| 久久久久久久久久久| 久久笫一福利免费导航| 影音先锋女人AV鲁色资源网久久| 久久99这里只有精品国产| 国产高清美女一级a毛片久久w| 国产精品狼人久久久久影院|