用 if....else 語句在處理多分支的時候,分支太多就會顯得不方便,且容易出現(xiàn) if 和 else 配對出現(xiàn)錯誤的情況,在 C 語言中提供了另外一種多分支選擇的語句——switch 語句,它的基本語法格式如下:
switch (表達式){
case 常量表達式1: 語句1;
case 常量表達式2: 語句2;
......
case 常量表達式 n: 語句 n;
default: 語句 n+1;
}
它的執(zhí)行過程是:首先計算“表達式”的值,然后從第一個 case 開始,與“常量表達式 x”進行比較,如果與當前常量表達式的值不相等,那么就不執(zhí)行冒號后邊的語句 x,一旦發(fā)現(xiàn)和某個常量表達式的值相等了,那么它會執(zhí)行之后所有的語句,如果直到最后一個“常量表達式 n”都沒有找到相等的值,那么就執(zhí)行 default 后的“語句 n+1”。請?zhí)貏e注意一點,當找到一個相等的 case 分支后,會執(zhí)行該分支以及之后所有分支的語句,很明顯這不是我們想要的結(jié)果。
在 C 語言中,有一條 break 語句,作用是跳出當前的循環(huán)語句,包括 for 循環(huán)和 while 循環(huán),同時,它還能用來結(jié)束 switch 語句塊。switch 的分支語句一共有 n+1 種,而我們通常希望的都是選擇其中的一個分支來執(zhí)行,執(zhí)行完后就結(jié)束整個 switch 語句,而繼續(xù)執(zhí)行 switch 后面的語句,此時就可以通過在每個分支后加上 break 語句來實現(xiàn)了。如下:
switch (表達式){
case 常量表達式1: 語句1; break;
case 常量表達式2: 語句2; break;
......
case 常量表達式 n: 語句 n; break;
default: 語句 n+1; break;
}
加了這個 break 語句后,一旦“常量表達式 x”與“表達式”的值相等了,那么就執(zhí)行“語句 x”,執(zhí)行完畢后,由于有了 break 則直接跳出 switch 語句,繼續(xù)執(zhí)行 switch 語句后面的程序了,這樣就可以避免執(zhí)行不必要的語句。了解了這個 switch 語句后,我們馬上會在本章程序中使用鞏固它。