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)文章
教你如何使用qt quick-PathView實(shí)現(xiàn)好看的home界面
pathView的使用類(lèi)似與ListView,都需要模型(model)和代理(delegate),只不過(guò)pathView多了一個(gè)路徑(path)屬性,顧名思義路徑就是item滑動(dòng)的路徑,下面給大家分享qt quick-PathView實(shí)現(xiàn)好看的home界面,一起看看吧2021-06-06C++結(jié)構(gòu)體struct和類(lèi)class區(qū)別詳解
struct和class有什么區(qū)別?最本質(zhì)的一個(gè)區(qū)別就是默認(rèn)的訪問(wèn)控制:默認(rèn)的繼承訪問(wèn)權(quán)限,struct是public的,class是private的。2017-11-11深入解析C語(yǔ)言中常數(shù)的數(shù)據(jù)類(lèi)型
C語(yǔ)言中常數(shù)的數(shù)據(jù)類(lèi)型,需要的朋友可以過(guò)來(lái)參考下。希望對(duì)大家有所幫助2013-10-10C++字符串拼接效率對(duì)比(+=、append、stringstream、sprintf)
這篇文章主要介紹了C++字符串拼接效率對(duì)比(+=、append、stringstream、sprintf),具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-08-08C語(yǔ)言指針應(yīng)用簡(jiǎn)單實(shí)例
這篇文章主要介紹了C語(yǔ)言指針應(yīng)用簡(jiǎn)單實(shí)例的相關(guān)資料,需要的朋友可以參考下2017-05-05