16種C語(yǔ)言編譯警告(Warning)類(lèi)型的解決方法
當(dāng)編譯程序發(fā)現(xiàn)程序中某個(gè)地方有疑問(wèn),可能有問(wèn)題時(shí)就會(huì)給出一個(gè)警告信息。警告信息可能意味著程序中隱含的大錯(cuò)誤,也可能確實(shí)沒(méi)有問(wèn)題。對(duì)于警告的正確處理方式應(yīng)該是:盡可能地消除之。對(duì)于編譯程序給出的每個(gè)警告都應(yīng)該仔細(xì)分析,看看是否真的有問(wèn)題。只有那些確實(shí)無(wú)問(wèn)題的警告才能放下不管。
說(shuō)明:
由于編譯的警告各種各樣,根本不可以一一羅列出來(lái),下面只是列舉出比較典型的一些警告,還有一些警告,大家只要根據(jù)字面意思,就可以很快的查找出來(lái),并解決之。
類(lèi)型1:
顯示:warning: implicit declaration of function 'Example()'。
警告原因:
在你的.c文件中調(diào)用了函數(shù)Example(),可是你并沒(méi)有把聲明這個(gè)函數(shù)的相應(yīng)的.h文件包含進(jìn)來(lái)。
有可能你在一個(gè).c文件中定義了這個(gè)函數(shù)體,但并沒(méi)有在.h中進(jìn)行聲明。
解決方法:
你可以在調(diào)用這種函數(shù)的.c文件的一開(kāi)始處加上:extern Example();
你可以在調(diào)用這種函數(shù)的.c文件中包含進(jìn)聲明了函數(shù)Example()的頭文件。
如果你在一個(gè).c文件中定義了這個(gè)函數(shù)體,但并沒(méi)有在.h中進(jìn)行聲明,不嫌麻煩的話(huà),你也可以去生成一個(gè).h文件,加上你的函數(shù)聲明。
類(lèi)似的警告:
warning: type mismatch with previous implicit declaration
warning: type mismatch with previous implicit declaration
warning: previous implicit declaration of 'Example()'
類(lèi)型2:
顯示:warning: unused variable 'param'。
警告原因:很明顯,是您定義了變量‘param',卻根本沒(méi)有使用它。
解決方法:不需要用的話(huà),就刪了它吧。
類(lèi)型3:
顯示:warning: statement with no effect。
警告原因:可能的情況是,在你的文件中,你這么干#define MACROPRINT
然后在某一處又定義了#define MACROPRINT printf。然后你在各處引用
MACROPRINT(“HELLO”),這樣不會(huì)出錯(cuò),但是發(fā)生了警告“這個(gè)聲明是沒(méi)有用的”。
解決方法:把#define MACROPRINT刪掉。
類(lèi)型4:
顯示:warning: int format, long int arg (arg 3)
警告原因: 象這樣printf("%s%d, szDebugString, ulGwId);你的ulGwId是一個(gè)unsigned long型的,而你為它選擇的輸出形式卻是 “%d”(這個(gè)格式是為整數(shù)型服務(wù)的-int)。
解決方法: 這樣的錯(cuò)誤你只要做到參數(shù)類(lèi)型一致就可以了,象上面的現(xiàn)象,你只要把“%d”改成“%d”就可以了。
類(lèi)似警告:warning:comparison between pointer and integer
類(lèi)型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ù)類(lèi)型限制了它的范圍,因此也就給出了警告。
解決方法:可以去掉這樣的判斷。
類(lèi)型6:
顯示:warning: control reaches end of non-void function
警告原因: 出現(xiàn)這樣的警告,有可能是你寫(xiě)了一個(gè)
unsigned long FuncA()
{
if()
{
return ulValue;
}
if()
{
return ulValue;
}
}
這樣的函數(shù),可能在兩個(gè)if語(yǔ)句中,你都沒(méi)有進(jìn)入,這時(shí),退出函數(shù)之前,你就根本沒(méi)有值可以返回。
解決辦法: 如果一個(gè)函數(shù)有返回值,確保在任何情況下該函數(shù)都有一個(gè)返回值。
類(lèi)似警告: warning :'return' with no value, in function returning non-void
類(lèi)型7:
顯示:warning: overflow in implicit constant conversion
警告原因:變量的變換有可能導(dǎo)致數(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},就會(huì)警告有出現(xiàn)越界。
解決辦法:確定好值的范圍。
類(lèi)型8:
顯示:warning: 'ulParam' might be used uninitialized in this function
警告原因: 當(dāng)ulParam做為表達(dá)式的右值時(shí),而在此之前,你又沒(méi)有對(duì)這個(gè)參數(shù)進(jìn)行初始化。
例如:
void Func()
{
ulong ulParam;
ulong ulRetCode;
if(…)
{
ulParam = ……;
}
if(….)
{
ulParam = ……;
}
ulRetCode = ulParam;
}
在這種情況下,當(dāng)兩個(gè)if()都執(zhí)行不到的時(shí)候,ulParam根本沒(méi)有被賦值過(guò),這樣又去給ulRetCode賦值,就比較危險(xiǎn)了。
解決辦法: 多留個(gè)神,細(xì)心一點(diǎn)就可以了。
類(lèi)型9:
顯示: warning: passing arg 1 of 'free' makes pointer from integer without a cast
警告原因: 你free(a),但a是一個(gè)unsigned long,你可能把一個(gè)指針的數(shù)值放在了a里面了。
解決辦法: 在free(a)時(shí),需要強(qiáng)制轉(zhuǎn)換a為指針類(lèi)型的即可。即:free((char*)a)。
類(lèi)似警告: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
類(lèi)型10:
顯示: warning: 'MY_DEBUG' redefined
warning: this is the location of the previous definition
警告原因: 連續(xù)出現(xiàn)這種兩個(gè)警告,可能的一種情況是,你在你的.c文件中包含了兩個(gè).h
文件,而這兩個(gè).h文件都對(duì)MY_DEBUG進(jìn)行了聲明。
解決辦法:只在一個(gè)文件中聲明這種東東。
類(lèi)型11:
顯示:warning: value computed is not used
警告原因:參與運(yùn)算的值是沒(méi)有作用的。比如你這樣干:
char* p;
*p++;
這樣對(duì)p根本一點(diǎn)影響也沒(méi)有。
解決方法:請(qǐng)確定究竟要進(jìn)行什么運(yùn)算。
類(lèi)型12:
顯示:warning: '#ifdef' argument starts with a digit
警告原因:出現(xiàn)了#ifdef 0這樣的錯(cuò)誤
解決方法:應(yīng)該是#if 0 吧
類(lèi)型13:
顯示:warning: unknown escape sequence '\R'
警告原因:編譯器不認(rèn)識(shí)‘\R'。
解決方法:一時(shí)筆誤,應(yīng)該是‘\r'。
類(lèi)型14:
顯示:warning:too few arguments for format
警告原因:你有可能這樣干了:printf(“%d%s”,uParam);
解決方法:把要的留下,不要的去掉。
類(lèi)型15:
顯示:warning: ‘Func' defined but not used
警告原因:Func 函數(shù)你定義了,但是你根本沒(méi)有使用它。
解決方法:不要的就去掉。
類(lèi)型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)文章
C++?Qt開(kāi)發(fā)之使用QNetworkAccessManager實(shí)現(xiàn)Web網(wǎng)頁(yè)訪(fǎng)問(wèn)
Qt?是一個(gè)跨平臺(tái)C++圖形界面開(kāi)發(fā)庫(kù),利用Qt可以快速開(kāi)發(fā)跨平臺(tái)窗體應(yīng)用程序,本文主要介紹了如何運(yùn)用QNetworkAccessManager組件實(shí)現(xiàn)Web網(wǎng)頁(yè)訪(fǎng)問(wèn),需要的可以參考下2024-03-03
教你5分鐘輕松搞定內(nèi)存字節(jié)對(duì)齊
隨便google一下,人家就可以跟你解釋的,一大堆的道理,我們沒(méi)怎么多時(shí)間,討論為何要對(duì)齊.直入主題,怎么判斷內(nèi)存對(duì)齊規(guī)則,sizeof的結(jié)果怎么來(lái)的,請(qǐng)牢記以下3條原則2013-09-09
C++控制臺(tái)實(shí)現(xiàn)密碼管理系統(tǒng)
這篇文章主要為大家詳細(xì)介紹了C++控制臺(tái)實(shí)現(xiàn)密碼管理系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-11-11
C語(yǔ)言實(shí)現(xiàn)洗牌發(fā)牌小程序
這篇文章主要介紹了C語(yǔ)言實(shí)現(xiàn)洗牌發(fā)牌小程序,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-04-04
opencv2實(shí)現(xiàn)10張圖像上下左右拼接融合
這篇文章主要為大家詳細(xì)介紹了opencv2實(shí)現(xiàn)10張圖像上下左右拼接融合,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-03-03
C/C++數(shù)據(jù)對(duì)齊詳細(xì)解析
通常我們?cè)趯?xiě)代碼的時(shí)候是不需要考慮對(duì)齊的影響的,都是依賴(lài)編譯器來(lái)為我們選擇適合的對(duì)齊策略,我們也可以通過(guò)傳遞給編譯器預(yù)編譯指令來(lái)指定數(shù)據(jù)對(duì)齊的方法2013-10-10
makefile如何調(diào)用靜態(tài)庫(kù)的方法實(shí)現(xiàn)
這篇文章主要介紹了makefile如何調(diào)用靜態(tài)庫(kù)的方法實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-12-12

