16種C語言編譯警告(Warning)類型的解決方法
當編譯程序發(fā)現(xiàn)程序中某個地方有疑問,可能有問題時就會給出一個警告信息。警告信息可能意味著程序中隱含的大錯誤,也可能確實沒有問題。對于警告的正確處理方式應該是:盡可能地消除之。對于編譯程序給出的每個警告都應該仔細分析,看看是否真的有問題。只有那些確實無問題的警告才能放下不管。
說明:
由于編譯的警告各種各樣,根本不可以一一羅列出來,下面只是列舉出比較典型的一些警告,還有一些警告,大家只要根據(jù)字面意思,就可以很快的查找出來,并解決之。
類型1:
顯示:warning: implicit declaration of function 'Example()'。
警告原因:
在你的.c文件中調(diào)用了函數(shù)Example(),可是你并沒有把聲明這個函數(shù)的相應的.h文件包含進來。
有可能你在一個.c文件中定義了這個函數(shù)體,但并沒有在.h中進行聲明。
解決方法:
你可以在調(diào)用這種函數(shù)的.c文件的一開始處加上:extern Example();
你可以在調(diào)用這種函數(shù)的.c文件中包含進聲明了函數(shù)Example()的頭文件。
如果你在一個.c文件中定義了這個函數(shù)體,但并沒有在.h中進行聲明,不嫌麻煩的話,你也可以去生成一個.h文件,加上你的函數(shù)聲明。
類似的警告:
warning: type mismatch with previous implicit declaration
warning: type mismatch with previous implicit declaration
warning: previous implicit declaration of 'Example()'
類型2:
顯示:warning: unused variable 'param'。
警告原因:很明顯,是您定義了變量‘param',卻根本沒有使用它。
解決方法:不需要用的話,就刪了它吧。
類型3:
顯示:warning: statement with no effect。
警告原因:可能的情況是,在你的文件中,你這么干#define MACROPRINT
然后在某一處又定義了#define MACROPRINT printf。然后你在各處引用
MACROPRINT(“HELLO”),這樣不會出錯,但是發(fā)生了警告“這個聲明是沒有用的”。
解決方法:把#define MACROPRINT刪掉。
類型4:
顯示:warning: int format, long int arg (arg 3)
警告原因: 象這樣printf("%s%d, szDebugString, ulGwId);你的ulGwId是一個unsigned long型的,而你為它選擇的輸出形式卻是 “%d”(這個格式是為整數(shù)型服務的-int)。
解決方法: 這樣的錯誤你只要做到參數(shù)類型一致就可以了,象上面的現(xiàn)象,你只要把“%d”改成“%d”就可以了。
類似警告:warning:comparison between pointer and integer
類型5:
顯示:warning: comparison is always 0 due to limited range of data type
警告原因:有可能你定義了unsigned int uParam;但是你去做了if(uparam<0)的判斷,
因 為unsigned int型的數(shù)據(jù)總是>=0的,因此這樣的比較由于數(shù)據(jù)類型限制了它的范圍,因此也就給出了警告。
解決方法:可以去掉這樣的判斷。
類型6:
顯示:warning: control reaches end of non-void function
警告原因: 出現(xiàn)這樣的警告,有可能是你寫了一個
unsigned long FuncA() { if() { return ulValue; } if() { return ulValue; } }
這樣的函數(shù),可能在兩個if語句中,你都沒有進入,這時,退出函數(shù)之前,你就根本沒有值可以返回。
解決辦法: 如果一個函數(shù)有返回值,確保在任何情況下該函數(shù)都有一個返回值。
類似警告: warning :'return' with no value, in function returning non-void
類型7:
顯示:warning: overflow in implicit constant conversion
警告原因:變量的變換有可能導致數(shù)值的越界。
#define RET_PRODUCTID 0x10000000 #define ERR_RET_GLOBAL RET_PRODUCTID+5000 #define RET_USER ERR_RET_GLOBAL+5000 #define USER_OK RET_USER+0 #define USER_FAIL RET_USER+1
如果這樣定義,碰到short Func(){return USER_OK},就會警告有出現(xiàn)越界。
解決辦法:確定好值的范圍。
類型8:
顯示:warning: 'ulParam' might be used uninitialized in this function
警告原因: 當ulParam做為表達式的右值時,而在此之前,你又沒有對這個參數(shù)進行初始化。
例如:
void Func() { ulong ulParam; ulong ulRetCode; if(…) { ulParam = ……; } if(….) { ulParam = ……; } ulRetCode = ulParam; }
在這種情況下,當兩個if()都執(zhí)行不到的時候,ulParam根本沒有被賦值過,這樣又去給ulRetCode賦值,就比較危險了。
解決辦法: 多留個神,細心一點就可以了。
類型9:
顯示: warning: passing arg 1 of 'free' makes pointer from integer without a cast
警告原因: 你free(a),但a是一個unsigned long,你可能把一個指針的數(shù)值放在了a里面了。
解決辦法: 在free(a)時,需要強制轉(zhuǎn)換a為指針類型的即可。即:free((char*)a)。
類似警告:warning: assignment from incompatible pointer type
warning: initialization from incompatible pointer type
warning:passing arg 2 of 'AOS_MemCopy_X' makes pointer from integer without a cast
類型10:
顯示: warning: 'MY_DEBUG' redefined
warning: this is the location of the previous definition
警告原因: 連續(xù)出現(xiàn)這種兩個警告,可能的一種情況是,你在你的.c文件中包含了兩個.h
文件,而這兩個.h文件都對MY_DEBUG進行了聲明。
解決辦法:只在一個文件中聲明這種東東。
類型11:
顯示:warning: value computed is not used
警告原因:參與運算的值是沒有作用的。比如你這樣干:
char* p;
*p++;
這樣對p根本一點影響也沒有。
解決方法:請確定究竟要進行什么運算。
類型12:
顯示:warning: '#ifdef' argument starts with a digit
警告原因:出現(xiàn)了#ifdef 0這樣的錯誤
解決方法:應該是#if 0 吧
類型13:
顯示:warning: unknown escape sequence '\R'
警告原因:編譯器不認識‘\R'。
解決方法:一時筆誤,應該是‘\r'。
類型14:
顯示:warning:too few arguments for format
警告原因:你有可能這樣干了:printf(“%d%s”,uParam);
解決方法:把要的留下,不要的去掉。
類型15:
顯示:warning: ‘Func' defined but not used
警告原因:Func 函數(shù)你定義了,但是你根本沒有使用它。
解決方法:不要的就去掉。
類型16:
顯示:warning: suggest parentheses around && within ||
警告原因:有人這么用了
if(( *p >= 'a' ) && ( *p <= 'z' ) || ( *p >= 'A' ) && ( *p <= 'Z' ) || ( *p >= '0' ) && ( *p <= '9' ))
解決方法:你最好這樣
if((( *p >= 'a' ) && ( *p <= 'z' )) || (( *p >= 'A' ) && ( *p <= 'Z' )) || (( *p >= '0' ) && ( *p <= '9' )))
相關(guān)文章
教你如何使用qt quick-PathView實現(xiàn)好看的home界面
pathView的使用類似與ListView,都需要模型(model)和代理(delegate),只不過pathView多了一個路徑(path)屬性,顧名思義路徑就是item滑動的路徑,下面給大家分享qt quick-PathView實現(xiàn)好看的home界面,一起看看吧2021-06-06C++結(jié)構(gòu)體struct和類class區(qū)別詳解
struct和class有什么區(qū)別?最本質(zhì)的一個區(qū)別就是默認的訪問控制:默認的繼承訪問權(quán)限,struct是public的,class是private的。2017-11-11C++字符串拼接效率對比(+=、append、stringstream、sprintf)
這篇文章主要介紹了C++字符串拼接效率對比(+=、append、stringstream、sprintf),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2023-08-08