有讀者問了這樣一個問題:我將IAR EWARM中的一個函數(shù),拷貝到Keil MDK-ARM中之后,編譯出錯了?
為什么在EWARM中可以編譯通過,卻在MDK-ARM中會出錯呢?
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);
??}
}
以上變量定義位置,相信很多人都看到過,有些朋友在實際編程中也常這么定義在這些位置。
答案:按照C89標準編譯就會出錯;按照C99標準編譯就不會出錯。
相信很多朋友在大學的時候都學過C和C++,學過C++的朋友都知道,上面那段代碼變量定義的位置是很合理的。
但不知道大家了解過C89和C99的區(qū)別,區(qū)別的內容還是有很多,針對本文說下定義變量位置的區(qū)別。
C89標準是不允許在函數(shù)中隨便位置聲明變量,C語言中的變量聲明不能放在任何可執(zhí)行語句之后,只允許在函數(shù)(可執(zhí)行語句)的開始處。
如上一段代碼,需要在【printf("a = %d\n", a);】這條語句之前。
C99及C++放松了限制,允許在函數(shù)體內任意位置聲明變量。C99新的標準滿足了在函數(shù)體內定義變量立馬就使用的功能。但是,也要注意變量的作用域。如下面代碼就會出錯:
void Test(void)
{
for(char c = 0; c < 10; c++)
{
printf("c = %d\n", c);
}
printf("c = %d\n", c);
}
上面說的問題,就是出在IDE的配置上。EWARM工程默認是支持C99標準的,而MDK-ARM工程默認是不支持C99標準的。所以說,將一個支持C99的標準的代碼拷貝到不支持C99標準的環(huán)境中,編譯就會因為代碼而出錯。
MDK-ARM和EWARM只需要修改一下配置就可以支持C99標準。
Project -> Options for Target -> C/C++ 勾選上“C99 Mode”即可。
Project -> Options -> C/C++ Compiler -> Language 1 選中上“C99”即可。
關于變量定義的位置也有很多爭議:有的人說為了兼容C89標準,都統(tǒng)一寫在可執(zhí)行語句前面;有的人則喜歡后面C99標準規(guī)定的,你認為呢?
------------?END?------------
Embedded Studio中使用ST-Link調試教程
關
注
微信公眾號『strongerHuang』,后臺回復“1024”查看更多內容,回復“加群”按規(guī)則加入技術交流群。
長按前往圖中包含的公眾號關注
點擊“
閱讀原文
”查看更多分享,歡迎點分享、收藏、點贊、在看。
免責聲明:本文內容由21ic獲得授權后發(fā)布,版權歸原作者所有,本平臺僅提供信息存儲服務。文章僅代表作者個人觀點,不代表本平臺立場,如有問題,請聯(lián)系我們,謝謝!