当编译程序发现程序中某个地方有疑问,可能有问题时就会给出一个警告信息。警告信息可能意味着程序中隐含的大错误,也可能确实没有问题。对于警告的正确处理方式应该是:尽可能地消除之。对于编译程序给出的每个警告都应该仔细分析,看看是否真的有问题。只有那些确实无问题的警告才能放下不管。

说明:

由于编译的警告各种各样,根本不可以一一罗列出来,下面只是列举出比较典型的一些警告,还有一些警告,大家只要根据字面意思,就可以很快的查找出来,并解决之。

类型1:

显示:warning: implicit declaration of function 'Example()'。

警告原因:在你的.c文件中调用了函数Example(),可是你并没有把声明这个函数的相应的.h文件包含进来。

有可能你在一个.c文件中定义了这个函数体,但并没有在.h中进行声明。

解决方法:你可以在调用这种函数的.c文件的一开始处加上:extern Example();

你可以在调用这种函数的.c文件中包含进声明了函数Example()的头文件。

如果你在一个.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”改成“%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型的数据总是>=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' )))

16种C语言编译警告(Warning)类型的解决方法的更多相关文章

  1. ios5 xcode 4.2 中 release显示编译警告或错误的解决方法

    转自:http://lizi464789754.blog.163.com/blog/static/1689370852011924113245778/ 由于 iOS5 xcode4.2 引入了ARC ...

  2. App开发流程之使用分类(Category)和忽略编译警告(Warning)

    Category使得开发过程中,减少了继承的使用,避免子类层级的膨胀.合理使用,可以在不侵入原类代码的基础上,写出漂亮的扩展内容.我更习惯称之为"分类". Category和Ext ...

  3. Android 源码编译及常见错误及解决方法

    最近要往arm开发板上移植android系统,大大小小的问题遇到了太多太多,都是泪啊.本人初接触嵌入式开发,对问题的根源不是太了解,不过好在每解决一个问题,便记录一下.话不多说,正式罗列问题: hos ...

  4. 源码编译apache报错的解决方法

    源码编译apache报错的解决方法   问题介绍 在源码编译安装httpd时,./configure执行无错误,到make时就报错,在网络上搜索了很多文章,很多方法如换apr-util的低版本并不能很 ...

  5. R语言—如何安装Github包的解决方法,亲测有效

    R语言—如何安装Github包的解决方法,亲测有效 准备安装材料: R包-REmap GitHub下载地址:https://github.com/lchiffon/REmap R包-baidumap ...

  6. C语言 消灭编译警告(Warning)

    如何看待编译警告 当编译程序发现程序中某个地方有疑问,可能有问题时就会给出一个警告信息.警告信息可能意味着程序中隐含的大错误,也可能确实没有问题.对于警告的正确处理方式应该是:尽可能地消除之.对于编译 ...

  7. Xcode 升级后,常常遇到的遇到的警告、错误,解决方法(转)

    从sdk3.2.5升级到sdk 7.1中间废弃了很多的方法,还有一些逻辑关系更加严谨了.1,警告:“xoxoxoxo”  is deprecated解决办法:查看xoxoxoxo的这个方法的文档,替换 ...

  8. warning C4819 的解决方法

    编译VC++程序的时候出现如下提示警告: warning C4819: The file contains a character that cannot be represented in the ...

  9. VC++ warning C4819 的解决方法(转)

    编译VC++程序的时候出现如下提示警告: warning C4819: The file contains a character that cannot be represented in the ...

随机推荐

  1. MariaDB 10.x 将包含多主复制功能

    本文内容遵从CC版权协议, 可以随意转载, 但必须以超链接形式标明文章原始出处和作者信息及版权声明网址: http://www.penglixun.com/tech/database/multi_so ...

  2. MRv1到MRv2

    概述 引入YARN作为通用资源调度平台后.Hadoop得以支持多种计算框架,如MapReduce.Spark.Storm等. MRv1是Hadoop1中的MapReduce,MRv2是Hadoop2中 ...

  3. 基于Dynamic Proxy技术的方法AOP拦截器开发

    在面向对象编程中,会用到大量的类,并且会多次调用类中的方法.有时可能需要对这些方法的调用进行一些控制.如在权限管理中,一些用户没有执行某些方法的权限.又如在日志系统中,在某个方法执行完后,将其执行的结 ...

  4. [深入理解Android卷一全文-第七章]深入理解Audio系统

    由于<深入理解Android 卷一>和<深入理解Android卷二>不再出版,而知识的传播不应该由于纸质媒介的问题而中断,所以我将在CSDN博客中全文转发这两本书的全部内容. ...

  5. 基于UEFI和GPT模式下U盘安装windows8.1和Linux双启动教程

    首先作以下准备: 1.一个8G以上的U盘,用的时候会格式化,建议为空 2.分区助手软件,官网下载链接 3.一个linux系统,这里用同学推荐的Fedora 26,官网下载链接 4.rufus 创建U盘 ...

  6. Makefileeasy犯错的语法

    1.引言 近期学习android的Build系统,接触最多的自然就是Makefile语法.发现非常多easy出错的地方,不避开这些错误语法没法真正了解Makefile的内涵.以下就介绍遇到的一些让人困 ...

  7. WINDOWS XP 系统显示乱码的解决方法(修改注册表,使用正常字体)

            一位同事的计算机进入WINDOWS XP系统后,电脑里的所有汉字全部显示乱码,很多办公文档无法打开而影响工作.因为第一次遇到这种问题,当然首先是百度解决了,搜索了相关的信息后找到了答案 ...

  8. Don't Block on Async Code

    http://blog.stephencleary.com/2012/07/dont-block-on-async-code.html This is a problem that is brough ...

  9. Java-Maven:POM百科

    ylbtech-Java-Maven:POM百科 Maven是以项目为中心的设计.POM(project object model)是Maven对一个单一项目的描述.没有POM的话,Maven是毫无用 ...

  10. SwiftUI 官方教程(七)

    7. 给子 View 传递数据 LandmarkDetail 现在依然使用硬编码的数据来显示地标.像 LandmarkRow 一样,LandmarkDetail 类型和它组合的其他 view 都需要一 ...