要采用small编译,这时C51是全部变量都按data! 自己不用去指定data。 变量超出80H空间,则出错,C51不会自动改成按idata或xdata等!!这时就要自己去指定idata或xdata。
把慢的变量自己去定义成idata或xdata! 这样省出空间给data。直到不出错为止。(注意,函数形参变量只能用data,不然keil会出错)
看M51文件就知道RAM分配的情况和CODE的大小!
idata可以访问00~FF全部内部RAM空间。 data后面就是idata,如果data变量在80H空间没用完,idata会紧跟其后,idata不会跳到80H开始。
变量除非data放不下,我们才去强行指定idata。idata放不下,才去强行xdata。
堆栈都是按idata来分配的,放在所有变量最后。---这就是KEIL C51自动分配堆栈的原理。
堆栈即使在80H空间内部,也是按idata来走!
如果变量太多,快占满了内部RAM,则留给堆栈的不多,虽然编译成功,但运行可能会出错!
保险起见,最好保证至少有16个字节留给堆栈,看M51文件。
原文链接:https://blog.csdn.net/wxlfreewind/article/details/125571192
|