函數(shù)體內(nèi)局部變量定義的問題
有讀者問了這樣一個問題:我將IAR EWARM中的一個函數(shù),拷貝到Keil MDK-ARM中之后,編譯出錯了?
為什么在EWARM中可以編譯通過,卻在MDK-ARM中會出錯呢?
1. 函數(shù)中變量的定義位置
大家先看下代碼中變量a、b、c、d定義的位置:
- void Test(void)
- {
- char a; //a定義的位置
- printf("a = %d\n", a);
- char b; //b定義的位置
- printf("b = %d\n", b);
- for(char c = 0; c < 10; c++) //c定義的位置
- {
- char d;
- printf("c = %d\n", c);
- printf("d = %d\n", d);
- }
- }
以上變量定義位置,相信很多人都看到過,有些朋友在實際編程中也常這么定義在這些位置。
上面這段代碼C編譯器編譯會錯嗎?答案:按照C89標準編譯就會出錯;按照C99標準編譯就不會出錯。
2. 變量定義位置的區(qū)別
相信很多朋友在大學(xué)的時候都學(xué)過C和C++,學(xué)過C++的朋友都知道,上面那段代碼變量定義的位置是很合理的。
但不知道大家了解過C89和C99的區(qū)別,區(qū)別的內(nèi)容還是有很多,針對本文說下定義變量位置的區(qū)別。
C89標準是不允許在函數(shù)中隨便位置聲明變量,C語言中的變量聲明不能放在任何可執(zhí)行語句之后,只允許在函數(shù)(可執(zhí)行語句)的開始處。如上一段代碼,需要在【printf("a = %d\n", a);】這條語句之前。
C99及C++放松了限制,允許在函數(shù)體內(nèi)任意位置聲明變量。C99新的標準滿足了在函數(shù)體內(nèi)定義變量立馬就使用的功能。但是,也要注意變量的作用域。如下面代碼就會出錯:
- void Test(void)
- {
- for(char c = 0; c < 10; c++)
- {
- printf("c = %d\n", c);
- }
- printf("c = %d\n", c); //這里有問題
- }
3. MDK-ARM和EWARM中C99的配置
上面說的問題,就是出在IDE的配置上。EWARM工程默認是支持C99標準的,而MDK-ARM工程默認是不支持C99標準的。所以說,將一個支持C99的標準的代碼拷貝到不支持C99標準的環(huán)境中,編譯就會因為代碼而出錯。
MDK-ARM和EWARM只需要修改一下配置就可以支持C99標準。
(1) MDK-ARM的配置Project -> Options for Target -> C/C++ 勾選上“C99 Mode”即可。
(2) EWARM的配置Project -> Options -> C/C++ Compiler -> Language 1 選中上“C99”即可。
關(guān)于變量定義的位置也有很多爭議:有的人說為了兼容C89標準,都統(tǒng)一寫在可執(zhí)行語句前面;有的人則喜歡后面C99標準規(guī)定的,你認為呢?