博客
关于我
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/

    你可能感兴趣的文章
    Mysql学习总结(33)——阿里云centos配置MySQL主从复制
    查看>>
    Mysql学习总结(35)——Mysql两千万数据优化及迁移
    查看>>
    Mysql学习总结(36)——Mysql查询优化
    查看>>
    Mysql学习总结(37)——Mysql Limit 分页查询优化
    查看>>
    Mysql学习总结(38)——21条MySql性能优化经验
    查看>>
    Mysql学习总结(39)——49条MySql语句优化技巧
    查看>>
    Mysql学习总结(3)——MySql语句大全:创建、授权、查询、修改等
    查看>>
    Mysql学习总结(40)——MySql之Select用法汇总
    查看>>
    Mysql学习总结(41)——MySql数据库基本语句再体会
    查看>>
    Mysql学习总结(42)——MySql常用脚本大全
    查看>>
    Mysql学习总结(43)——MySQL主从复制详细配置
    查看>>
    Mysql学习总结(44)——Linux下如何实现mysql数据库每天自动备份定时备份
    查看>>
    Mysql学习总结(45)——Mysql视图和事务
    查看>>
    Mysql学习总结(46)——8种常被忽视的SQL错误用法
    查看>>
    Mysql学习总结(48)——MySql的日志与备份还原
    查看>>
    Mysql学习总结(49)——从开发规范、选型、拆分到减压
    查看>>
    Mysql学习总结(4)——MySql基础知识、存储引擎与常用数据类型
    查看>>
    Mysql学习总结(50)——Oracle,mysql和SQL Server的区别
    查看>>
    Mysql学习总结(51)——Linux主机Mysql数据库自动备份
    查看>>
    Mysql学习总结(52)——最全面的MySQL 索引详解
    查看>>