我试图实现一个函数来更改菜单的状态,但是当它离开该函数时,我的引用丢失了:
void gotoLowerlevel(Menu *item)
{
if (item->chld != 0x00) {
item = item->chld;
}
}
函数调用以这种方式完成(
currentState
是指向struct Menu
的指针):case ENTER:
if (cnsle->inMenuFlag == 0)
{
cnsle->inMenuFlag = 1;
cnsle->currentState = cnsle->root;
gotoLowerlevel(cnsle->currentState);
displayMenu(cnsle->currentState,&cnsle->display);
}
我不知道为什么这不管用。有什么想法吗?
最佳答案
item
中的gotoLowerLevel
是局部变量,即使它是对其他对象的引用。要修改cnsle->currentState
,您需要:
传入cnsle
传入对cnsle->currentState
的引用(即将方法签名更改为Menu ** itemptr
,将调用参数更改为&cnsle->currentState
)
或者从gotoLowerLevel
返回新值并分配给它:cnsle->currentState = gotoLowerLevel(cnsle->currentState)
我的首选项是最后一个选项,因为这在读取调用代码时很清楚currentState
可能会被修改。
其他人已经解释了如何通过推荐信。我首选解决方案的代码是:
Menu* gotoLowerlevel(Menu *item)
{
if (item->chld != 0x00) {
item = item->chld;
}
return item;
}
/* .... */
cnsle->currentState = gotoLowerlevel(cnsle->currentState);
关于c - 通过引用传递不会更改变量,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/8938412/