C語言switch使用之詭異用法詳解
關於switch的用法這裡不再做什麼總結了,其實這個是一個便捷的快速跳轉條件切換器。而關於這個功能最常用的技術討論點在於case後面的break以及default。這裡不討論這些,直接看下面的程式碼:
#include"stdio.h" int main(void) { int num = 0; switch(num) { printf("functionrun!\n"); } return 0; }
上面的程式碼中用到了一個switch,但是程式碼塊中沒有任何case以及default。程式碼語法有問題嗎?
編譯一下如下:
E:\WorkSpace\02_技術實踐\01_程式語言\01_C語言\02_C和指標\switch>gcc switch.c
E:\WorkSpace\02_技術實踐\01_程式語言\01_C語言\02_C和指標\switch>
由上面的結果可以看到,編譯沒有任何問題。那麼執行會是什麼狀態呢?會把這個唯一的printf執行輸出相應的語句?
執行如下:
E:\WorkSpace\02_技術實踐\01_程式語言\01_C語言\02_C和指標\switch>a
E:\WorkSpace\02_技術實踐\01_程式語言\01_C語言\02_C和指標\switch>
如此看,就有點詭異了。這個printf語句是沒有執行到的!也就是說,switch語句中的程式碼執行必須得有case標籤指示程式碼的入口。這種行為很讓人聯想到一種情況的程式執行結果,程式碼如下:
#include"stdio.h" int main(void) { int num = 0; switch(num) { int i = 123; printf("functionrun!\n"); default: printf("value of iis:%d\n",i); break; } return 0; }
程式碼是在之前的程式碼中修改的,程式碼的第二個printf會執行,可是執行的時候i的數值是多少呢?從之前的測試可以看出,區域性變數後面的程式碼是沒有執行過的,那麼我這個i在每次函式執行到這裡的時候會每次動態性初始化嗎?
程式碼編譯執行結果:
E:\WorkSpace\02_技術實踐\01_程式語言\01_C語言\02_C和指標\switch>gcc switch.c
E:\WorkSpace\02_技術實踐\01_程式語言\01_C語言\02_C和指標\switch>a value of i is:2
E:\WorkSpace\02_技術實踐\01_程式語言\01_C語言\02_C和指標\switch>
從上面的結果可以得出兩個結論:
1,程式碼塊中的宣告定義是起作用的;
2,i的數值不是123證明這部分的區域性變數並沒有進行每次的動態初始化。
說起來這也是夠奇怪的一個特點,印象中之前看《C專家程式設計》的時候似乎看到過一個類似的描述,但是那時候C語言的水平看《C專家程式設計》一點也看不懂。只是留下了一個模模糊糊的印象,至於是否是一個問題,有空還是得會去查查。
以上這篇C語言switch使用之詭異用法詳解就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。