前面有小伙伴問了這樣一個問題:
我將EWIAR中的一個函數拷貝到MDK-ARM中之后,發現編譯出錯了。為什么在EWARM中可以編譯通過,但在MDK-ARM中會出錯呢?
我一看代碼,基本上判斷問題大概出在什么位置。經過進一步分析得出錯誤原因:就是函數里面局部變量定義的位置不對導致的錯誤。
針對上面的問題,這個問題大家可能在實際項目中不常見,但牽涉的知識也有必要向大家分享。
Ⅰ
函數中變量的定義位置
大家先看下代碼中變量a、b、c、d定義的位置:
void Test(void)
{
char a;
printf("a = %d\n", a);
char b;
printf("b = %d\n", b);
for(char c = 0;c < 10; c++)
{
char d;
printf("c = %d\n", c);
printf("d = %d\n", d);
}
}
以上變量定義位置,相信很多人都看到過,有些朋友在實際編程中也常這么定義在這些位置。
上面這段代碼C編譯器編譯會錯嗎?
答案:按照C89標準編譯就會出錯;按照C99標準編譯就不會出錯。
Ⅱ
變量定義位置的區別
相信很多朋友在大學的時候都學過C和C++,學過C++的朋友都知道,上面那段代碼變量定義的位置是很合理的。
但不知道大家了解過C89和C99的區別,區別的內容還是有很多,針對本文說下定義變量位置的區別。
C89標準是不允許在函數中隨便位置聲明變量,C語言中的變量聲明不能放在任何可執行語句之后,只允許在函數(可執行語句)的開始處。如上一段代碼,需要在【printf("a = %d\n", a);】這條語句之前。
C99及C++放松了限制,允許在函數體內任意位置聲明變量。C99新的標準滿足了在函數體內定義變量立馬就使用的功能。但是,也要注意變量的作用域。如下面代碼,紅色的語句就會出錯。
void Test(void)
{
for(char c = 0; c < 10; c++)
{
printf("c = %d\n", c);
}
printf("c = %d\n", c);
}
Ⅲ
MDK-ARM和EWARM中C99的配置
文章開篇說的問題,就是出在IDE的配置上。EWARM工程默認是支持C99標準的,而MDK-ARM工程默認是不支持C99標準的。所以說,將一個支持C99的標準的代碼拷貝到不支持C99標準的環境中,編譯就會因為代碼而出錯。
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”即可。
關于變量定義的位置也有很多爭議:有的人說為了兼容C89標準,都統一寫在可執行語句前面;有的人則喜歡后面C99標準規定的,這種比較隨性,隨定隨用。我也沒有什么好的建議,看個人吧。
-
ARM處理器
+關注
關注
6文章
360瀏覽量
41663 -
編譯器
+關注
關注
1文章
1618瀏覽量
49049 -
MDK
+關注
關注
4文章
209瀏覽量
32033
發布評論請先 登錄
相關推薦
評論