C51中 return语句在main()函数中的副作用追踪

2020-01-25 15:21发布

先说结论:
1、        C51中mian()并不是被调用的,而是跳转进去的;
2、        在main()中调用return语句,将会从栈中弹出SP大小的数据到SP中,进而程序会运行到弹出数据指向的地址,C51中可能就是SP指针返回0x0000。

    昨天和我合作一个工程的同事在调试的时候,发现单片机程序会经常出现重启的现象,当时我认为可能是数组溢出、指针越界导致的程序跑飞。
    后来同事将有问题的语句定位到某个分支中的“return 0;”语句上,我一看这居然是在main()函数上使用了“return 0;”,认为程序会在调用这个语句后,
PC指针离开main(),继续执行main()函数后面的代码导致程序跑飞(同事估计是受到VC等PC编译环境的影响,汗~)。
    不过,回到坐位后却想起return对应的指令,会负责将栈中的值取出来赋值给PC指针,这样的话执行“return 0;”后应该返回到调用main()函数的地方。
    既然有疑问就动手吧,首先向同事拿到了出问题的工程,在main()开始的地方设置了两个“return 0;”(分别是第25行和32行)。
    然后进入仿真模式,如下图,可以观察到sp指针指向起始值0x07,PC指针指向0x0000,PC指针的长度为2。
图8.jpg (34.86 KB, 下载次数: 0) 下载附件 2013-12-4 09:44 上传
图8
友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
32条回答
yaake
1楼-- · 2020-01-27 02:59
mcu_lover 发表于 2013-12-4 17:02
加个变量就可以了啊

if(condition_true)

嗯,这样加个判断应该可以。多谢回复。
typedef
2楼-- · 2020-01-27 07:27
chencc8 发表于 2013-12-4 15:20
在9.0版本上,定义成int main(),并且没有while(1)的话就报错:MAIN.C(28): warning C290: missing retur ...

您研究得真仔细,当时注意到,但也只是避过就算了
RelayProtect
3楼-- · 2020-01-27 10:31
楼主的钻研精神值得学习
wkman
4楼-- · 2020-01-27 14:18
 精彩回答 2  元偷偷看……
iquer
5楼-- · 2020-01-27 15:17
为什么要在main中加return……
cyberjok
6楼-- · 2020-01-27 20:48
iquer 发表于 2013-12-6 21:15
为什么要在main中加return……

应该是C99 标准要求 main要有返回值。

一周热门 更多>