C語(yǔ)言的使用的詳解
C語(yǔ)言雖然沒(méi)有限制 if else 能夠處理的分支數(shù)量,但當(dāng)分支過(guò)多時(shí),用 if else 處理會(huì)不太方便,而且容易出現(xiàn) if else 配對(duì)出錯(cuò)的情況。例如,輸入一個(gè)整數(shù),輸出該整數(shù)對(duì)應(yīng)的星期幾的英文表示:
#includeint main(){ int a; printf("Input integer number:"); scanf("%d",&a); if(a==1){ printf("Mondayn"); }else if(a==2){ printf("Tuesdayn"); }else if(a==3){ printf("Wednesdayn"); }else if(a==4){ printf("Thursdayn"); }else if(a==5){ printf("Fridayn"); }else if(a==6){ printf("Saturdayn"); }else if(a==7){ printf("Sundayn"); }else{ printf("errorn"); } return 0;}
運(yùn)行結(jié)果:
Input integer number:3
Wednesday
C語(yǔ)言還提供了另外一種多分支選擇的語(yǔ)句——switch 語(yǔ)句,它的基本語(yǔ)法格式如下:
switch(表達(dá)式){
case 常量表達(dá)式1: 語(yǔ)句 1;
case 常量表達(dá)式2: 語(yǔ)句 2;
......
case 常量表達(dá)式n: 語(yǔ)句 n;
default: 語(yǔ)句 n+1;
}
它的執(zhí)行過(guò)程是:首先計(jì)算“表達(dá)式”的值,然后從第一個(gè) case 開(kāi)始,與“常量表達(dá)式x”進(jìn)行比較,如果與當(dāng)前常量表達(dá)式的值不相等,那么就不執(zhí)行冒號(hào)后邊的語(yǔ)句 x,一旦發(fā)現(xiàn)和某個(gè)常量表達(dá)式的值相等了,那么它會(huì)執(zhí)行之后所有的語(yǔ)句,如果直到最后一個(gè)“常量表達(dá)式 n”都沒(méi)有找到相等的值,那么就執(zhí)行 default 后的“語(yǔ)句 n+1”。
需要注意的是,當(dāng)找到一個(gè)相等的 case 分支后,會(huì)執(zhí)行該分支以及之后所有分支的語(yǔ)句。例如:
#includeint main(){ int a; printf("Input integer number:"); scanf("%d",&a); switch(a){ case 1: printf("Mondayn"); case 2: printf("Tuesdayn"); case 3: printf("Wednesdayn"); case 4: printf("Thursdayn"); case 5: printf("Fridayn"); case 6: printf("Saturdayn"); case 7: printf("Sundayn"); default:printf("errorn"); } return 0;}
運(yùn)行結(jié)果:
Input integer number:4
Thursday
Friday
Saturday
Sunday
error
輸入4,發(fā)現(xiàn)和第四個(gè)分支匹配,于是就執(zhí)行第四個(gè)分支以及后面的所有分支。這顯然不是我們想要的結(jié)果,我們希望只執(zhí)行第四個(gè)分支,跳過(guò)后面的所有分支。
為了避免這種情況,C語(yǔ)言還提供了一個(gè)關(guān)鍵字 break,專門用于跳出switch語(yǔ)句。
switch 的分支語(yǔ)句一共有 n+1 種,而我們通常希望的都是選擇其中的一個(gè)分支來(lái)執(zhí)行,執(zhí)行完后就結(jié)束整個(gè) switch 語(yǔ)句,而繼續(xù)執(zhí)行 switch后面的語(yǔ)句,此時(shí)就可以通過(guò)在每個(gè)分支后加上 break 語(yǔ)句來(lái)實(shí)現(xiàn)了。如下:
switch (表達(dá)式){
case 常量表達(dá)式1: 語(yǔ)句1; break;
case 常量表達(dá)式2: 語(yǔ)句2; break;
......
case 常量表達(dá)式n: 語(yǔ)句n; break;
default: 語(yǔ)句n+1; break;
}
加了這個(gè) break 語(yǔ)句后,一旦“常量表達(dá)式 x”與“表達(dá)式”的值相等了,那么就執(zhí)行“語(yǔ)句 x”,執(zhí)行完畢后,由于有了 break 則直接跳出 switch 語(yǔ)句,繼續(xù)執(zhí)行 switch 語(yǔ)句后面的程序了,這樣就可以避免執(zhí)行不必要的語(yǔ)句。
使用switch語(yǔ)句修改上面的代碼:
#includeint main(){ int a; printf("Input integer number:"); scanf("%d",&a); switch(a){ case 1: printf("Mondayn"); break; case 2: printf("Tuesdayn"); break; case 3: printf("Wednesdayn"); break; case 4: printf("Thursdayn"); break; case 5: printf("Fridayn"); break; case 6: printf("Saturdayn"); break; case 7: printf("Sundayn"); break; default:printf("errorn"); break; } return 0;}
運(yùn)行結(jié)果:
Input integer number:4
Thursday
值得一提的是,由于default是最后一個(gè)分支,匹配后不會(huì)再執(zhí)行其他分支,所以也可以不用break;語(yǔ)句。
【C語(yǔ)言的使用的詳解】相關(guān)文章:
c語(yǔ)言stack(棧)和heap(堆)的使用詳解08-23
c語(yǔ)言字符數(shù)組與字符串的使用詳解08-19
c語(yǔ)言中有關(guān)隨機(jī)函數(shù)的使用詳解07-23
詳解c語(yǔ)言字符數(shù)組與字符串的使用09-19
C語(yǔ)言中32個(gè)關(guān)鍵字使用詳解07-17
C語(yǔ)言typedef的使用09-24
C語(yǔ)言的內(nèi)存使用09-23
C語(yǔ)言變量的使用10-12