消滅編譯警告(Warning)
如何看待編譯警告
當編譯程式發現程式中某個地方有疑問,可能有問題時就會給出一個警告資訊。警告資訊可能意味著程式中隱含的大錯誤,也可能確實沒有問題。對於警告的正確處理方式應該是:儘可能地消除之。對於編譯程式給出的每個警告都應該仔細分析,看看是否真的有問題。只有那些確實無問題的警告才能放下不管。
說明:
由於編譯的警告各種各樣,根本不可以一一羅列出來,下面只是列舉出比較典型的一些警告,還有一些警告,大家只要根據字面意思,就可以很快的查找出來,並解決之。
型別1:
顯示:warning: implicit declaration of function `Example()'。
警告原因:(1)在你的.c檔案中呼叫了函式Example(),可是你並沒有把宣告這個函式的相應的.h檔案包含進來。
(2)有可能你在一個.c檔案中定義了這個函式體,但並沒有在.h中進行宣告。
解決方法:(1)你可以在呼叫這種函式的.c檔案的一開始處加上:extern Example();
(2)你可以在呼叫這種函式的.c檔案中包含進聲明瞭函式Example()的標頭檔案。
(3)如果你在一個.c檔案中定義了這個函式體,但並沒有在.h中進行宣告,不嫌麻煩的話,你也可以去生成一個.h檔案,加上你的函式宣告。
類似的警告: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”),這樣不會出錯,但是發生了警告“這個宣告是沒有用的”。
解決方法:把#define MACROPRINT刪掉。
型別4:
顯示:warning: int format, long int arg (arg 3)
警告原因: 象這樣printf("%s%d, szDebugString, ulGwId);你的ulGwId是一個unsigned long 型的,而你為它選擇的輸出形式卻是 “%d”(這個格式是為整數型服務的-int)。
解決方法: 這樣的錯誤你只要做到引數型別一致就可以了,象上面的現象,你只要把“%d”改成“%ld”就可以了。
類似警告: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 型的資料總是>=0的,因此這樣的比較由於資料型別限制了它的範圍,因此也就給出了警告。
解決方法:可以去掉這樣的判斷。
型別6:
顯示:warning: control reaches end of non-void function
警告原因: 出現這樣的警告,有可能是你寫了一個
unsigned long FuncA()
{
if()
{return ulValue;}
if()
{ return ulValue;}
}的函式,可能在兩個if語句中,你都沒有進入,這時,退出函式之前,你就根本沒有值可以返回。
解決辦法: 如果一個函式有返回值,確保在任何情況下該函式都有一個返回值。
類似警告: warning :`return' with no value, in function returning non-void
型別7:
顯示:warning: overflow in implicit constant conversion
警告原因:變數的變換有可能導致數值的越界。
#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},就會警告有出現越界。
解決辦法:確定好值的範圍。
型別8:
顯示:warning: `ulParam' might be used uninitialized in this function
警告原因: 當ulParam做為表示式的右值時,而在此之前,你又沒有對這個引數進行初始化。
例如:void Func()
{
ulong ulParam;
ulong ulRetCode;
if(…)
{
ulParam = ……..;
}
if(….)
{
ulParam = ……;
}
ulRetCode = ulParam;
}
在這種情況下,當兩個if()都執行不到的時候,ulParam根本沒有被賦值過,這樣又去給ulRetCode賦值,就比較危險了。
解決辦法: 多留個神,細心一點就可以了。
型別9:
顯示: warning: passing arg 1 of `free' makes pointer from integer without a cast
警告原因: 你free(a),但a是一個unsigned long,你可能把一個指標的數值放在了a裡面了。
解決辦法: 在free(a)時,需要強制轉換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
警告原因: 連續出現這種兩個警告,可能的一種情況是,你在你的.c檔案中包含了兩個.h
檔案,而這兩個.h檔案都對MY_DEBUG進行了宣告。
解決辦法:只在一個檔案中宣告這種東東。
型別11:
顯示:warning: value computed is not used
警告原因:參與運算的值是沒有作用的。比如你這樣幹:
char* p;
*p++;
這樣對p根本一點影響也沒有。
解決方法:請確定究竟要進行什麼運算。
型別12:
顯示:warning: `#ifdef' argument starts with a digit
警告原因:出現了#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 函式你定義了,但是你根本沒有使用它。
解決方法:不要的就去掉。
型別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' )))
---------------------
作者:myaccella
來源:CSDN
原文:https://blog.csdn.net/myaccella/article/details/7003188
版權宣告:本文為博主原創文章,轉載請