“extern 变量”问题求助!
我的一个程序有这样一句:
while(!tm1count);
其中tm1count是在本.c文件中申明的一个外部变量:
extern uint32_t tm1count;
tm1count值的改变是在另一个.c文件中的定时器中断服务函数(匹配中断)中:
tm1count++;
并在这个.c文件顶端定义:
uint32_t tm1count = 0;
问题是:tm1count在正常的增加,但是上面while语句却始终退出,一直在执行,诡异了!用仿真看,tm1count也确实在增加,!tm1count表达式的值也等于0x00000000,但是while就是不退出,一直在里面执行。另外我如果把while(!tm1count);写在tm1count所在的.c文件文件中就没有问题正常运行。
特来求助,实在搞不定!芯片是LPC1766,keil4
[解决办法]
tm1count输出看一下
[解决办法]
你试试把这句改成声明(不赋值)
uint32_t tm1count = 0;
改成:
uint32_t tm1count ;
然后在某个初始化函数中
tm1count = 0;
然后:tm1count++;
再然后: extern uint32_t tm1count;
再调用这个判断:
while(!tm1count) { // dosomething }
[解决办法]
[解决办法]
是不是这样的?
中断服务函数响应的时候,CPU保护现场的时候,将tm1count值放入寄存器中,中断服务函数完成的时候,从寄存器中恢复这个值,没有读取tm1count所在的内存地址?
以上是猜的,能不能把汇编贴出来看看?
[解决办法]
[解决办法]
你修改下优化等级试试吧。而且 volatile可能是你在声明extern的时候这个关键字就已经被忽略了。好像这点标准上有说明。
[解决办法]
VC调试(TC或BC用TD调试)时按Alt+8、Alt+6和Alt+5,打开汇编窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应内存和寄存器变化,这样过一遍不就啥都明白了吗。
对VC来说,所谓‘调试时’就是编译连接通过以后,按F10或F11键单步执行一步以后的时候,或者在某行按F9设了断点后按F5执行停在该断点处的时候。
(Linux或Unix下可以在用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
想要从本质上理解C指针,必须学习汇编以及C和汇编的对应关系。
从汇编的角度理解和学习C语言的指针,原本看似复杂的东西就会变得非常简单!
指针即地址。“地址又是啥?”“只能从汇编语言和计算机组成原理的角度去解释了。”
提醒:
“学习用汇编语言写程序”
和
“VC调试(TC或BC用TD调试)时按Alt+8、Alt+6和Alt+5,打开汇编窗口、内存窗口和寄存器窗口看每句C对应的汇编、单步执行并观察相应内存和寄存器变化,这样过一遍不就啥都明白了吗。
(Linux或Unix下可以在用GDB调试时,看每句C对应的汇编并单步执行观察相应内存和寄存器变化。)
想要从本质上理解C指针,必须学习C和汇编的对应关系。”
不是一回事!
不要迷信书、考题、老师、回帖;
要迷信CPU、编译器、调试器、运行结果。
并请结合“盲人摸太阳”和“驾船出海时一定只带一个指南针。”加以理解。
任何理论、权威、传说、真理、标准、解释、想象、知识……都比不上摆在眼前的事实!
无汇编,无真相!
[解决办法]
我就说应该volatile是可以解决问题的。