问题描述
这是我正在尝试构建的伪代码(ish)。
这是中断函数。按下开关 2 时,potval = 1。按下开关 3 时,potval = 2。每次按下开关,potval 都会更新。
void interruptJ_function (void){ //if i change to int interruptJ_function,it says that it was expecting a void function
if(Pim.pifj.byte & 0x01) { //switch2 is pressed
potval = 1;
Pim.pifj.byte |= 0x01; //clear interrupt bit
//return potval; //doing this says the result is returned in void-result-function
}
else if(Pim.pifj.byte & 0x02) { //switch 3 is pressed
potval = 2;
Pim.pifj.byte |= 0x02; //clear interrupt bit
//return potval;
}
//return potval;
}
这里是 main.c.
int potval;
unsigned int i;
void main ()
{
adt(potval); //Warning: Result of function call is ignored
for (;;); //recurring loop until interrupt initiated
}
int adt(int potval,unsigned int i) {
if(potval == 1){
//for (;;){
while(potval==1){ //breaks when potval =2
i= Atd0.atddr[0].d10; //ATD bits
light7segment(i); // ATD changes number on 7segment display
m_delay(50);
}
}
else if (potval == 2){
light7segment(10); //ATD turns off 7segment display
}
}
解决方法
当您调用具有返回值的函数但忽略检查该返回值时,Codewarrior 会发出此警告。正如您在这里所做的那样:
adt(potval);
通常的解决方案是 (void) adt(potval);
。
但在这种情况下不是,因为原因是一个更严重的错误,即函数 int adt(int potval,unsigned int i)
没有 return
值。在大多数 Codewarrior 目标系统上,这意味着调用者代码将从累加器中获取一些随机值,然后跑到树林里。如果您在编译器在不同的警告中说“预期返回”时注意,本可以避免此错误。