ARM编程中的警告和错误处理

转载自:(以后补充)


KEIL  warning解决方法 

在做数据处理的时候,出现warning: #223-D: function "abs" declared implicitly

添加:float abs(float __x);//防止abs warning, 原因不明确, 可能是math.hstdlib.h中都有abs()吧,用stdlib.h替换math.h也可解决问题

1.       warning: #550-D: variable "d" was set but never used

描述:变量'd'定义但从未使用,或者是,虽然这个变量你使用了,但编译器认为变量d所在的语句没有意义,编译器把它优化了.

解决:仔细衡量所定义的变量d是否有用,若是认定变量d所在语句有意义,那么尝试用volatile关键字修饰变量d,若是真的没有用,那么删除掉以释放可能的内存.

2.       warning: #1-D: last line of file ends without a newline

描述:文件最后一行不是新的一行.编译器要求程序文件的最后一行必须是空行,想了半天没想通为什么要这样.

解决:可以不理会.若是觉得出现警告不爽,那么在出现警告的文件的最后一行敲个回车,空出一行.

 

3.       warning: #111-D: statement is unreachable

描述:声明不可能到达.多出现在这种场合:

int main(void)
{

...

while(1) //无限循环,这在不使用操作系统的程序中最常见

{

...

 

}

 

return 0; //这句声明在正常情况下不可能执行到,编译器发出警告

}

 

解决:不理会.

 

4.       warning: C3017W: data may be used before being set

描述:变量'data'在使用前没有明确的赋值.:

uint8 i,data; //定义变量idata,二者都没有明确赋值

 

for ( i = 0; i < 8; i++) //变量'i'在语句中被赋值0

{

if ( IO1PIN & SO_CC2420 )

data |= 0x01; //变量'data'在使用前没有明确赋值,编译器发出警告

else

data &= ~0x01;

}

解决:应仔细衡量该变量的初始值是否为0,若是,可以不理会这个警告,因为MDK编译器在程序执行前,会将使用到的数据区初始化为0,但若是该变量的初始值不应该是0,忽略这个警告可能会引起致命错误.这个警告应引起足够重视.应养成变量赋初值的习惯,好在有编译器给把关.

 

5.       warning: #177-D: variable "temp" was declared but never referenced

描述:变量'temp'进行了声明但没有引用.多出现在声明了一个变量,但却没有使用它,它和warning: #550-D: variable "temp" was set but never used不同之处在于temp从没有使用过.

解决:若是定义的变量确实没有用,删除掉;若是有用,则在程序中使用.

与该警告类似的还有 warning: #177-D: function "MACProcessBeacon" was declared but never referenced

 

6.       warning: #940-D: missing return statement at end of non-void function "DealwithInspect2"

描述:返回非空的函数"DealwithInspect2"的最后缺少返回值声明.:

int DealwithInspect2(uint32 test)

{

...

...

...

//此处应该是return x;返回一个int型数据,若是没有返回值,编译器产生警告

}

 

KEIL error解决方法

 

1.       error: #65: expected a ";"

描述:缺少分号.大多是漏忘';'.

解决:双击错误行,在定位到错误点的附近找到没加';'号的语句,加上分号.并不一定在定位到的错误行才却分号,可能是这行的上一行,也可能是下一行.

 

2.       error: #65: expected a ";" error: #20: identifier "xxxx" is undefined一块出现,而且后面的error: #20错误可能一大堆

描述:这个错误对于第一次遇上的人来说绝对是个噩梦,当错误出现,满怀希望的双击错误提示,来到错误行时却愕然发现,错误行绝对没有错,于是找找错误行的上一行,下一行,没有错误,再找上上行,下下行...让人无比郁闷的事情出现了:编译提示的所有错误行都不可能有错误出现.其实这最可能是你在.h文件声明外部变量或者函数时,没有在声明语句的最后加分号!如果你有很多模块,main.c,lcd.c,key.c...有很多头文件,lcd.h,key.h,若是在lcd.h文件声明函数时没有加分号,那么这种错误可能定为到main.c,所以要检查所有头文件.

解决:仔细检查.h文件,将分号补上.

 

3.       Error: L6200E: Symbol flagu multiply defined (by uart0.o and main.o).

描述:变量(也是一种符号)flagu多处定义(uart0.c中和main.c都定义了).通常错在全局变量定义重复.比如:main.c中定义全局变量flagu:

 

uint8 flagu=0;

 

uart0.c中也用到该变量,于是声明此变量,我通常都是先复制定义的变量再在变量前面加关键字extern修饰:

 

extern uint8 flagu=0;

 

然后编译,就会出现上面的连接错误,原因在于,我在uart0.c中是又定义了一个变量,而不是声明变量,因为我给变量赋了初值"flagu=0",这样就重复定义了变量flag.正确的声明方法是去掉赋值部分:

 

extern uint8 flagu;

 

解决办法:找到重复定义的变量,看情况修改一处.

 

4.       error: #159: declaration is incompatible with previous "wr_lcd" (declared at line 40)

描述:wr_lcd函数还没有声明之前就已经使用了.多出现在两种情况:第一种,wr_lcd函数体还没有写,就已经用到了它,这种情况多出现在写一个程序的大体结构中,只是简单写一下框架.第二种情况比较常见,函数a调用函数b,但函数b的函数体在函数a的下面:

void a(void) //函数a的实体

{

b(); //调用函数b

}

 

void b(void) //函数b的实体

{

...

}

这样如果点编译,就会产生error: #159的错误,因为当函数a调用函数b,发现在这之前都没有函数b的任何声明.
解决方法:在函数a调用函数b之前,对函数b进行声明,:
void b(void); //
对函数b进行声明

void a(void) //
函数a的实体
{
b(); //
调用函数b
}

void b(void) //
函数b的实体
{
...
}

5.asm00.sct(7): error: L6236E: No section matches selector - no section to be FIRST/LAST.

解决方法: 

Options for Target ' xxxx ',里面的Linker选项下面: 

 

  • 去掉勾选
  • Use Memory Layout from Target Dialog 
  • 清空 Acatter File里面的内容 

6.Error: L6411E: No compatible library exists with definition of startup symbol __main.

Target not created

Warning: L6665W: Neither Lib$$Request$$armlib Lib$$Request$$cpplib defined, not 
searching ARM libraries.

解决方法:

启动代码里面有一句,它要引用_main这个变量的,默认的启动代码会等一个main函数,如果没有就删除,或者是有,但写错了。

7.error: L6031U: Could not open scatter description file ASM_2.sct: No such file or directory

解决方法:

target optionLinker选项卡下面,取消“scatter file

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值