• 单片机KEIL C51堆栈地址分配原理,变量放RAM,small编译按data


    STC单片机12C5A60S2,内部RAM低128字节(变量用“data”声明)+高128字节(变量用“idata”声明)+内部扩展RAM1024字节(变量用“xdata”声明)

    要采用small编译,这时C51是全部变量都按data! 自己不用去指定data。 变量超出80H空间,则出错,C51不会自动改成按idata或xdata等!!这时就要自己去指定idata或xdata。

    把慢的变量自己去定义成idata或xdata!  这样省出空间给data。直到不出错为止。

    看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文件。

  • 相关阅读:
    Elasticsearch-8.4.2 集群安装
    现货黄金职业交易员怎么使用技术分析?
    优雅的用户体验:微信小程序中的多步骤表单引导
    基于SSM的网上书城系统
    数据分析之人力资源管理驾驶舱
    Mybatis-动态SQL
    MobPush Android 快速集成
    Linux磁盘管理(CentOS)
    光线投射之伪3d
    成人专升本
  • 原文地址:https://blog.csdn.net/wxlfreewind/article/details/125571192