日韩黑丝制服一区视频播放|日韩欧美人妻丝袜视频在线观看|九九影院一级蜜桃|亚洲中文在线导航|青草草视频在线观看|婷婷五月色伊人网站|日本一区二区在线|国产AV一二三四区毛片|正在播放久草视频|亚洲色图精品一区

分享

C語言switch case語句詳解

 飛往天際 2019-07-15
C語言雖然沒有限制 if else 能夠處理的分支數(shù)量,但當分支過多時,用 if else 處理會不太方便,而且容易出現(xiàn) if else 配對出錯的情況。例如,輸入一個整數(shù),輸出該整數(shù)對應(yīng)的星期幾的英文表示:
  1. #include <stdio.h>

  2. int main(){

  3. int a;

  4. printf("Input integer number:");

  5. scanf("%d",&a);

  6. if(a==1){

  7. printf("Monday\n");

  8. }else if(a==2){

  9. printf("Tuesday\n");

  10. }else if(a==3){

  11. printf("Wednesday\n");

  12. }else if(a==4){

  13. printf("Thursday\n");

  14. }else if(a==5){

  15. printf("Friday\n");

  16. }else if(a==6){

  17. printf("Saturday\n");

  18. }else if(a==7){

  19. printf("Sunday\n");

  20. }else{

  21. printf("error\n");

  22. }

  23. return 0;

  24. }

運行結(jié)果:
Input integer number:3↙
Wednesday

對于這種情況,實際開發(fā)中一般使用 switch 語句代替,請看下面的代碼:
  1. #include <stdio.h>

  2. int main(){

  3. int a;

  4. printf("Input integer number:");

  5. scanf("%d",&a);

  6. switch(a){

  7. case 1: printf("Monday\n"); break;

  8. case 2: printf("Tuesday\n"); break;

  9. case 3: printf("Wednesday\n"); break;

  10. case 4: printf("Thursday\n"); break;

  11. case 5: printf("Friday\n"); break;

  12. case 6: printf("Saturday\n"); break;

  13. case 7: printf("Sunday\n"); break;

  14. default:printf("error\n"); break;

  15. }

  16. return 0;

  17. }

運行結(jié)果:
Input integer number:4↙
Thursday

switch 是另外一種選擇結(jié)構(gòu)的語句,用來代替簡單的、擁有多個分枝的 if else 語句,基本格式如下:

switch(表達式){
    case 整型數(shù)值1: 語句 1;
    case 整型數(shù)值2: 語句 2;
    ......
    case 整型數(shù)值n: 語句 n;
    default: 語句 n+1;
}

它的執(zhí)行過程是:
1) 首先計算“表達式”的值,假設(shè)為 m。

2) 從第一個 case 開始,比較“整型數(shù)值1”和 m,如果它們相等,就執(zhí)行冒號后面的所有語句,也就是從“語句1”一直執(zhí)行到“語句n+1”,而不管后面的 case 是否匹配成功。

3) 如果“整型數(shù)值1”和 m 不相等,就跳過冒號后面的“語句1”,繼續(xù)比較第二個 case、第三個 case……一旦發(fā)現(xiàn)和某個整型數(shù)值相等了,就會執(zhí)行后面所有的語句。假設(shè) m 和“整型數(shù)值5”相等,那么就會從“語句5”一直執(zhí)行到“語句n+1”。

4) 如果直到最后一個“整型數(shù)值n”都沒有找到相等的值,那么就執(zhí)行 default 后的“語句 n+1”。

需要重點強調(diào)的是,當和某個整型數(shù)值匹配成功后,會執(zhí)行該分支以及后面所有分支的語句。例如:
  1. #include <stdio.h>

  2. int main(){

  3. int a;

  4. printf("Input integer number:");

  5. scanf("%d",&a);

  6. switch(a){

  7. case 1: printf("Monday\n");

  8. case 2: printf("Tuesday\n");

  9. case 3: printf("Wednesday\n");

  10. case 4: printf("Thursday\n");

  11. case 5: printf("Friday\n");

  12. case 6: printf("Saturday\n");

  13. case 7: printf("Sunday\n");

  14. default:printf("error\n");

  15. }

  16. return 0;

  17. }

運行結(jié)果:
Input integer number:4↙
Thursday
Friday
Saturday
Sunday
error

輸入4,發(fā)現(xiàn)和第四個分支匹配成功,于是就執(zhí)行第四個分支以及后面的所有分支。這顯然不是我們想要的結(jié)果,我們希望只執(zhí)行第四個分支,而跳過后面的其他分支。為了達到這個目標,必須要在每個分支最后添加break;語句。

break 是C語言中的一個關(guān)鍵字,專門用于跳出 switch 語句。所謂“跳出”,是指一旦遇到 break,就不再執(zhí)行 switch 中的任何語句,包括當前分支中的語句和其他分支中的語句;也就是說,整個 switch 執(zhí)行結(jié)束了,接著會執(zhí)行整個 switch 后面的代碼。

使用 break 修改上面的代碼:
  1. #include <stdio.h>

  2. int main(){

  3. int a;

  4. printf("Input integer number:");

  5. scanf("%d",&a);

  6. switch(a){

  7. case 1: printf("Monday\n"); break;

  8. case 2: printf("Tuesday\n"); break;

  9. case 3: printf("Wednesday\n"); break;

  10. case 4: printf("Thursday\n"); break;

  11. case 5: printf("Friday\n"); break;

  12. case 6: printf("Saturday\n"); break;

  13. case 7: printf("Sunday\n"); break;

  14. default:printf("error\n"); break;

  15. }

  16. return 0;

  17. }

運行結(jié)果:
Input integer number:4↙
Thursday

由于 default 是最后一個分支,匹配后不會再執(zhí)行其他分支,所以也可以不添加break;語句。

最后需要說明的兩點是:
1) case 后面必須是一個整數(shù),或者是結(jié)果為整數(shù)的表達式,但不能包含任何變量。請看下面的例子:
  1. case 10: printf("..."); break; //正確

  2. case 8+9: printf("..."); break; //正確

  3. case 'A': printf("..."); break; //正確,字符和整數(shù)可以相互轉(zhuǎn)換

  4. case 'A'+19: printf("..."); break; //正確,字符和整數(shù)可以相互轉(zhuǎn)換

  5. case 9.5: printf("..."); break; //錯誤,不能為小數(shù)

  6. case a: printf("..."); break; //錯誤,不能包含變量

  7. case a+10: printf("..."); break; //錯誤,不能包含變量


2) default 不是必須的。當沒有 default 時,如果所有 case 都匹配失敗,那么就什么都不執(zhí)行。

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多