博客
关于我
MDK中的RW RO ZI ROM的含义
阅读量:87 次
发布时间:2019-02-26

本文共 932 字,大约阅读时间需要 3 分钟。

程序大小分析:ARM程序的代码与数据结构解析

在ARM开发中,理解程序大小与内存占用是优化和调试的重要环节。本文将详细解析ARM程序中的代码与数据结构,帮助开发者更好地理解程序运行机制。

程序运行时,芯片内部的存储空间主要由以下几个部分组成:

  • 代码空间(Code)

    存储到flash(ROM)中的程序代码,包括所有指令和函数。代码是程序的核心执行单元,直接影响程序的运行效率。

  • 只读数据(RO Data)

    包含常量和静态常量(const型),这些数据在编译时已被确定,且不会被修改。只读数据存储在ROM中,具有持久性。

  • 可读写数据(RW Data)

    这些变量在初始化时已赋值,程序运行时可读写。RW数据存储在RAM中,需注意其占用会影响系统性能。

  • 未初始化数据(Zero-Initialized Data,ZI Data)

    这些变量在编译时未被初始化,Keil编译器默认赋值为0。ZI数据存储在RAM中,程序运行时需通过特定指令清零。

  • 程序烧写时,flash中的占用空间为:代码空间 + 只读数据 + 可读写数据。

    程序运行时,RAM中的占用空间为:可读写数据 + 未初始化数据。

    以下是典型ARM程序的编译结果示例:

    • Code(代码):2730字节
    • RO Data(只读数据):194字节
    • RW Data(可读写数据):250字节
    • ZI Data(未初始化数据):8字节
    • 总计:2730 + 194 + 250 + 8 = 2980字节(约2.91KB)

    总ROM占用空间为:2730 + 194 + 250 = 2988字节(约2.92KB)。

    理解这些数据对优化程序性能至关重要。通过合理管理RW和ZI数据的使用,可以有效降低程序运行时的内存占用。

    需要注意的是,ZI数据通常不包含在ROM中,因为这些数据在程序启动时会被清零,包含ZI数据会增加无谓的存储开销。

    在程序设计中,应确保ROM中包含以下功能:

  • 将RW数据从ROM复制到RAM,确保变量能够正常使用。
  • 初始化ZI区域的RAM,通常采用清零方式。
  • 确保程序在启动时完成上述准备工作,否则变量访问将直接失败。
  • 通过合理规划代码、只读数据和可读写数据的使用,可以最大限度地优化程序的存储占用和运行效率。

    转载地址:http://xvvk.baihongyu.com/

    你可能感兴趣的文章
    OAuth2 + Gateway统一认证一步步实现(公司项目能直接使用),密码模式&授权码模式
    查看>>
    OAuth2 Provider 项目常见问题解决方案
    查看>>
    OAuth2 vs JWT,到底怎么选?
    查看>>
    Vue.js 学习总结(14)—— Vue3 为什么推荐使用 ref 而不是 reactive
    查看>>
    oauth2-shiro 添加 redis 实现版本
    查看>>
    OAuth2.0_JWT令牌-生成令牌和校验令牌_Spring Security OAuth2.0认证授权---springcloud工作笔记148
    查看>>
    OAuth2.0_JWT令牌介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记147
    查看>>
    OAuth2.0_介绍_Spring Security OAuth2.0认证授权---springcloud工作笔记137
    查看>>
    OAuth2.0_完善环境配置_把资源微服务客户端信息_授权码存入到数据库_Spring Security OAuth2.0认证授权---springcloud工作笔记149
    查看>>
    OAuth2.0_授权服务配置_Spring Security OAuth2.0认证授权---springcloud工作笔记140
    查看>>
    OAuth2.0_授权服务配置_三项内容_Spring Security OAuth2.0认证授权---springcloud工作笔记141
    查看>>
    OAuth2.0_授权服务配置_令牌服务和令牌端点配置_Spring Security OAuth2.0认证授权---springcloud工作笔记143
    查看>>
    OAuth2.0_授权服务配置_客户端详情配置_Spring Security OAuth2.0认证授权---springcloud工作笔记142
    查看>>
    OAuth2.0_授权服务配置_密码模式及其他模式_Spring Security OAuth2.0认证授权---springcloud工作笔记145
    查看>>
    OAuth2.0_授权服务配置_授权码模式_Spring Security OAuth2.0认证授权---springcloud工作笔记144
    查看>>
    OAuth2.0_授权服务配置_资源服务测试_Spring Security OAuth2.0认证授权---springcloud工作笔记146
    查看>>
    OAuth2.0_环境介绍_授权服务和资源服务_Spring Security OAuth2.0认证授权---springcloud工作笔记138
    查看>>
    OAuth2.0_环境搭建_Spring Security OAuth2.0认证授权---springcloud工作笔记139
    查看>>
    oauth2.0协议介绍,核心概念和角色,工作流程,概念和用途
    查看>>
    OAuth2.0四种模式的详解
    查看>>