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

            文章均收錄自他人博客,但不喜標(biāo)題前加-[轉(zhuǎn)貼],因其丑陋,見(jiàn)諒!~
            隨筆 - 1469, 文章 - 0, 評(píng)論 - 661, 引用 - 0
            數(shù)據(jù)加載中……

            if和switch效率的再研究

            昨天發(fā)現(xiàn)了一本叫做CSAPP的書(shū),終于找到了關(guān)于switch問(wèn)題的解答。
            這是一段C代碼:


            GCC匯編出來(lái)的代碼如下:

            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部分被分配了一個(gè)連續(xù)的查找表,switch case中不連續(xù)的部分也被添加上了相應(yīng)的條目,switch表的大小不是根據(jù)case語(yǔ)句的多少,而是case的最大值的最小值之間的間距。在選擇相應(yīng) 的分支時(shí),會(huì)先有一個(gè)cmp子句,如果大于查找表的最大值,則跳轉(zhuǎn)到default子句。而其他所有的case語(yǔ)句的耗時(shí)都回事O(1)

            相比于if-else結(jié)構(gòu),switch的效率絕對(duì)是要高很多的,但是switch使用查找表的方式?jīng)Q定了case的條件必須是一個(gè)連續(xù)的常量。而if-else則可以靈活的多。

            posted on 2008-12-17 16:47 肥仔 閱讀(1082) 評(píng)論(1)  編輯 收藏 引用 所屬分類(lèi): C++ 基礎(chǔ)

            評(píng)論

            # re: if和switch效率的再研究[未登錄](méi)  回復(fù)  更多評(píng)論   

            標(biāo)準(zhǔn)中沒(méi)有規(guī)定怎么處理,因此具體結(jié)果依賴(lài)于不同的編譯器。
            2008-12-17 20:13 | Chipset
            久久久噜噜噜久久| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 93精91精品国产综合久久香蕉| 91久久九九无码成人网站| 欧美与黑人午夜性猛交久久久| 18禁黄久久久AAA片| 久久91精品国产91久久麻豆| 日批日出水久久亚洲精品tv| 久久精品中文騷妇女内射| 日韩欧美亚洲综合久久影院Ds| 久久水蜜桃亚洲av无码精品麻豆| 精品欧美一区二区三区久久久| 蜜臀av性久久久久蜜臀aⅴ麻豆 | 中文国产成人精品久久不卡| 久久99国产精品久久久 | 日产精品久久久久久久性色| 久久精品99无色码中文字幕| 77777亚洲午夜久久多喷| 精品久久久久成人码免费动漫| 99久久精品午夜一区二区| 超级碰碰碰碰97久久久久| 热久久国产欧美一区二区精品| 久久精品国产亚洲AV无码娇色 | 国内精品久久久久久久涩爱| 91久久精一区二区三区大全| 亚洲午夜久久久久久噜噜噜| 亚洲国产成人久久综合野外| 久久久久国色AV免费看图片| 国产精品日韩欧美久久综合| 久久国产精品-国产精品| 精品国产VA久久久久久久冰| 日韩精品久久无码中文字幕| 久久久久亚洲AV无码观看| 久久久SS麻豆欧美国产日韩| 久久只这里是精品66| 2021久久精品免费观看| 波多野结衣AV无码久久一区| 亚洲精品乱码久久久久久蜜桃图片 | 久久精品视频一| 三级三级久久三级久久 | 久久亚洲私人国产精品|