Keil 编译内存信息:Program size: Code, RO-data , RW-data, ZI-data 学习


Keil 编译内存信息:Program size: Code, RO-data , RW-data, ZI-data 学习

一、用keil编译程序后会打印对应的内存分配信息,例如如Program Size: Code=97782 RO-data=9578 RW-data=2992 ZI-data=87696  ,如下图所示:

Keil 编译内存信息:Program size: Code, RO-data , RW-data, ZI-data 学习_第1张图片


二、这里我们就解释一下Program size: Code, RO-data , RW-data, ZI-data具体代表什么?

      1、Code 是代码占用的空间。

      2、RO-data是 Read Only 只读常量的大小,如const型。

     3、RW-data是(Read Write) RW是可读可写变量,就是初始化时候就已经赋值了的,RW + ZI就是你的程序总共使用的RAM字节数。

     4、ZI-data是(Zero Initialize) 没有初始化的可读写变量的大小,就是程序中用到的变量并且被系统初始化为0的变量的字节数,keil编译器默认是把你没有初始化的变量都赋值一个0,这些变量在程序运行时是保存在RAM中的。

三、Total ROM Size (Code + RO Data + RW Data)这样所写的程序占用的ROM的字节总数,也就是说程序所下载到ROM flash 中的大小。为什么Rom中还要存RW,因为掉电后RAM中所有数据都丢失了,每次上电RAM中的数据是被重新赋值的,每次这些固定的值就是存储在Rom中的,为什么不包含ZI段呢,是因为ZI数据都是0,没必要包含,只要程序运行之前将ZI数据所在的区域一律清零即可。包含进去反而浪费存储空间。

四、MCU执行过程是先将RW从ROM中搬到RAM中,因为RW是变量,变量不能存在ROM中。然后将ZI所在的RAM区域全部清零,因为ZI区域并不在Image中,所以需要程序根据编译器给出的ZI地址及大小来将相应得RAM区域清零。ZI中也是变量,同理:变量不能存在ROM中。ROM中的指令完成了这两项工作后C程序才能正常访问变量。否则只能运行不含变量的代码。

五、用keil编译器实际测试学习。

1、目前我的这个工程编译后内存分配大小如下:

Keil 编译内存信息:Program size: Code, RO-data , RW-data, ZI-data 学习_第2张图片

2、现在我在程序里面加入一个int   Program_Size[10]= {10};如下图所示,RW-data增加了40个字节,因为这个数组已经初始化了,代码放到RW-data。

Keil 编译内存信息:Program size: Code, RO-data , RW-data, ZI-data 学习_第3张图片


3、如果是加入一个int   Program_Size[10];数组不进行已经初始化,如下图所示,ZI-data区增加40个字节。

Keil 编译内存信息:Program size: Code, RO-data , RW-data, ZI-data 学习_第4张图片

3、如果是加入一个int   Program_Size[10]={0};数组进行已经初始化都是0,如下图所示,ZI-data区增加40个字节,说明初始化都是0和进行已经初始化,都是放ZI-data区。

Keil 编译内存信息:Program size: Code, RO-data , RW-data, ZI-data 学习_第5张图片


你可能感兴趣的:(C和C++语言)