加入星計(jì)劃,您可以享受以下權(quán)益:

  • 創(chuàng)作內(nèi)容快速變現(xiàn)
  • 行業(yè)影響力擴(kuò)散
  • 作品版權(quán)保護(hù)
  • 300W+ 專業(yè)用戶
  • 1.5W+ 優(yōu)質(zhì)創(chuàng)作者
  • 5000+ 長(zhǎng)期合作伙伴
立即加入
  • 正文
    • 14.6  Switch語(yǔ)句
  • 相關(guān)推薦
  • 電子產(chǎn)業(yè)圖譜
申請(qǐng)入駐 產(chǎn)業(yè)圖譜

高效的C編程之:Switch語(yǔ)句

2013/09/30
閱讀需 10 分鐘
加入交流群
掃碼加入
獲取工程師必備禮包
參與熱點(diǎn)資訊討論

14.6  Switch語(yǔ)句

編譯器通常將C語(yǔ)言中的Switch語(yǔ)句編譯一個(gè)查找表(Table Lookup)以便跳轉(zhuǎn)到合適的入口處。

下面的例子顯示了編譯器如何處理程序中的Switch語(yǔ)言的。

C源程序如下。

char * ConditionStr1(int condition)

{

switch(condition)

{

case 0: return "EQ";

case 1: return "NE";

case 2: return "CS";

case 3: return "CC";

case 4: return "MI";

case 5: return "PL";

case 6: return "VS";

case 7: return "VC";

case 8: return "HI";

case 9: return "LS";

case 10: return "GE";

case 11: return "LT";

case 12: return "GT";

case 13: return "LE";

case 14: return "";

default: return 0;

}

}

編譯后的結(jié)果如下。

ConditionStr1:

   0000807C E1A01000  MOV      r1,r0

>>> SWITCH#3 switch(condition)

   00008080 E351000E  CMP      r1,#0xe

   00008084 908FF101  ADDLS    pc,pc,r1,LSL #2

   00008088 EA00003B  B        0x817c                     <SWITCH#20>

   0000808C EA00000D  B        0x80c8                     <SWITCH#5>

   00008090 EA00000F  B        0x80d4                     <SWITCH#6>

   00008094 EA000011  B        0x80e0                     <SWITCH#7>

   00008098 EA000013  B        0x80ec                     <SWITCH#8>

   0000809C EA000015  B        0x80f8                     <SWITCH#9>

   000080A0 EA000017  B        0x8104                     <SWITCH#10>

   000080A4 EA000019  B        0x8110                     <SWITCH#11>

   000080A8 EA00001B  B        0x811c                     <SWITCH#12>

   000080AC EA00001D  B        0x8128                     <SWITCH#13>

   000080B0 EA00001F  B        0x8134                     <SWITCH#14>

   000080B4 EA000021  B        0x8140                     <SWITCH#15>

   000080B8 EA000023  B        0x814c                     <SWITCH#16>

   000080BC EA000025  B        0x8158                     <SWITCH#17>

   000080C0 EA000027  B        0x8164                     <SWITCH#18>

   000080C4 EA000029  B        0x8170                     <SWITCH#19>

對(duì)于ARM代碼,查找表的入口為4字節(jié);Thumb代碼的查找表入口為1或2個(gè)字節(jié)(當(dāng)Case情況小于32時(shí),使用入口為1字節(jié)的查找表)。所以當(dāng)使用Switch語(yǔ)句時(shí),應(yīng)盡量較少Case分支。

另外,為了提高系統(tǒng)性能,也可以手工編寫代碼,形成程序跳轉(zhuǎn)來(lái)避免使用Switch語(yǔ)句。

下面的例子顯示對(duì)上面Switch分支語(yǔ)句的改寫。

char * ConditionStr2(int condition)

{

if ((unsigned) condition >= 15) return 0;

return

         "EQ