c語言中case的用法
本文已影響
1.57W人
C語言是一門實踐性和動手能力要求很高的大學主幹課程,但是C語言實驗課的教學一直不受重視,教學效果也不太理想。下面小編就跟你們詳細介紹下c語言中case的用法,希望對你們有用。 c語言中case的用法如下: “case常量表達式只是起語句標號作用,並不是該處進行條件判斷。在執行switch語句時,根據switch的表達式,找到與之匹配的case語句,就從此case子句執行下去,不在進行判斷,直到碰到break或函數結束爲止。” 使用switch語句直接處理多個分支(當然包括兩個分支).其一般形式爲: switch(表達式) { case 常量表達式1: 語句1; break; case 常量表達式2: 語句2; break; …… case 常量表達式n: 語句n; break; default: 語句n+1; break; } switch語句的執行流程是:首先計算switch後面圓括號中表達式的值,然後用此值依次與各個case的常量表達式比較,若圓括號中表達式的值與某個case後面的常量表達式的值相等,就執行此case後面的語句,執行後遇break語句就退出switch語句;若圓括號中表達式的值與所有case後面的常量表達式都不等,則執行default後面的語句n+1,然後退出switch語句,程序流程轉向開關語句的下一個語句. 以上是switch-case的正規寫法,default語句總是寫在最後。但是,如果把default語句間在了case的中間,執行的結果又是怎樣的呢?筆者測試了一下幾種有代表性的情況,把結果簡單羅列如下: A. 每個語句中break齊整 switch(c) { case '1': printf("1n"); break; default: printf("defaultn"); break; case '2': printf("2n"); break; case '3': printf("3n"); break; } 此種情況最爲規整,default寫在中間跟寫在最後的效果一致。 B. default語句後沒有break switch(c) { case '1': printf("1n"); break; default: printf("defaultn"); // break; case '2': printf("2n"); break; case '3': printf("3n"); break; } 此種情況下,輸入分別爲 1、 2、 3、 4,對應的輸出分別爲 1、 2 、3、 default 2(換行省略了,實際運行時有換行的);即此種情況下遵循A中的執行順序和一般的標號規則。 C. 最後一個case沒有break switch(c) { case '1': printf("1n"); break; default: printf("defaultn"); break; case '2': printf("2n"); break; case '3': printf("3n"); // break; } 此種情況下,輸入分別爲 1、 2、 3、 4,對應的輸出分別爲1、2、3、default.可見實際的運行效果並不等同於把default語句挪到最後的運行效果。否則,輸入爲3時,輸出應該爲 3 default. D. default和最後一個case都沒有break switch(c) { case '1': printf("1n"); break; default: printf("defaultn"); // break; case '2': printf("2n"); break; case '3': printf("3n"); // break; } 由上面A,B,C三種情況的運行結果,我們可以推測出D這種情況的運行結果。當輸入分別爲 1、2、3、4時,輸出爲1、2、3、default 2. 結果與B的情況相同。