您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“c語(yǔ)言中如何實(shí)現(xiàn)switch反匯編”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“c語(yǔ)言中如何實(shí)現(xiàn)switch反匯編”這篇文章吧。
在分支較多的時(shí)候,switch的效率比if高,在反匯編中我們即可看到效率高的原因
1、當(dāng)switch存在3個(gè)分支時(shí)
當(dāng)去掉break的時(shí)候
#include<stdio.h> void Function(int x) { switch (x) { case 1: printf("1"); case 2: printf("2"); case 3: printf("3"); default: printf("4"); } } int main() { Function(2); return 0; }
可以看出,此時(shí)switch的反匯編代碼與if語(yǔ)句無(wú)異。
當(dāng)有四個(gè)if語(yǔ)句的時(shí)候就會(huì)生成大表。
步驟:
1、將傳進(jìn)來(lái)的數(shù)先減去1,再進(jìn)行比較。判斷出該參數(shù)是否超過(guò)switch語(yǔ)句中最大常量還,即判斷參數(shù)是直接進(jìn)入default中還是進(jìn)入case中
2、 若參數(shù)<=max,則用寄存器保留該值。并代入表達(dá)式中,通過(guò)大表直接跳到相應(yīng)的地址
注意
分支少于四個(gè),則switch無(wú)意義,編譯器會(huì)按if…else…語(yǔ)句進(jìn)行反匯編
case后的常量的順序不影響大表的生成
將常量值的順序打亂,觀察反匯編代碼
正向代碼
匯編代碼
這里可以看到大表里面都是自己排好序了。
將連續(xù)的10項(xiàng)中抹去1項(xiàng)或者2項(xiàng),觀察反匯編有無(wú)變化
正向代碼是這樣的
這里可以看到有幾個(gè)地址是一樣的
可以發(fā)現(xiàn)是指向默認(rèn)的地址。
就會(huì)生成小表
步驟:
1、將傳進(jìn)來(lái)的參數(shù)減去最小值,然后跟最大值相比,如果大于的話就跳到默認(rèn)的地方,不然就用差值去查小表,然后查大表。
編譯器按照if…else…進(jìn)行反匯編
以上是“c語(yǔ)言中如何實(shí)現(xiàn)switch反匯編”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。