您好,登錄后才能下訂單哦!
這篇文章主要介紹“如何理解函數體內局部變量定義的問題”,在日常操作中,相信很多人在如何理解函數體內局部變量定義的問題問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”如何理解函數體內局部變量定義的問題”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
1. 函數中變量的定義位置
大家先看下代碼中變量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. 變量定義位置的區別
相信很多朋友在大學的時候都學過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); //這里有問題 }
3. 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標準規定的,你認為呢?
到此,關于“如何理解函數體內局部變量定義的問題”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。