Keil 编译内存信息:Program size: Code, RO-data , RW-data, ZI-data 学习
2018-03-13 16:21
771 查看
Keil 编译内存信息:Program size: Code, RO-data , RW-data, ZI-data 学习
一、用keil编译程序后会打印对应的内存分配信息,例如如Program Size: Code=97782 RO-data=9578 RW-data=2992 ZI-data=87696 ,如下图所示:
![](//img-blog.csdn.net/20180313155235329)
二、这里我们就解释一下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、目前我的这个工程编译后内存分配大小如下:
![](//img-blog.csdn.net/20180313160821138)
2、现在我在程序里面加入一个int Program_Size[10]= {10};如下图所示,RW-data增加了40个字节,因为这个数组已经初始化了,代码放到RW-data。
![](//img-blog.csdn.net/20180313161000606)
3、如果是加入一个int Program_Size[10];数组不进行已经初始化,如下图所示,ZI-data区增加40个字节。
![](//img-blog.csdn.net/20180313161258464)
3、如果是加入一个int Program_Size[10]={0};数组进行已经初始化都是0,如下图所示,ZI-data区增加40个字节,说明初始化都是0和进行已经初始化,都是放ZI-data区。
一、用keil编译程序后会打印对应的内存分配信息,例如如Program Size: Code=97782 RO-data=9578 RW-data=2992 ZI-data=87696 ,如下图所示:
二、这里我们就解释一下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、目前我的这个工程编译后内存分配大小如下:
2、现在我在程序里面加入一个int Program_Size[10]= {10};如下图所示,RW-data增加了40个字节,因为这个数组已经初始化了,代码放到RW-data。
3、如果是加入一个int Program_Size[10];数组不进行已经初始化,如下图所示,ZI-data区增加40个字节。
3、如果是加入一个int Program_Size[10]={0};数组进行已经初始化都是0,如下图所示,ZI-data区增加40个字节,说明初始化都是0和进行已经初始化,都是放ZI-data区。
相关文章推荐
- Keil/MDK :Program size: Code, RO-data , RW-data, ZI-data 解释
- Keil/MDK 小知识点:Program size: Code, RO-data , RW-data, ZI-data 解释(什么意思)
- Keil/MDK 小知识点:Program size: Code, RO-data , RW-data, ZI-data 解释(什么意思)
- Keil/MDK 小知识点:Program size: Code, RO-data , RW-data, ZI-data 解释(什么意思)
- keil编译后code,RO-data,RW-data,ZI-data含义及mcu的flash实际存储数据
- keil编译后code,RO-data,RW-data,ZI-data含义及mcu的flash实际存储数据
- KEIL MDK Program Size 查看代码量、RAM使用情况--RO-data、RW-data、ZI-data的解释
- Program Size: Code=7044 RO-data=268 RW-data=112 ZI-data=8736解析
- MDK编译信息分析(code,ro-data,rw-data,zi-data)
- KEIL编译后Program Size: Code=1032 RO-data=336 RW-data=12 ZI-data=1836 的含义
- keil编译的CODE.RW.RO.ZI的大小说明
- Keil MDK Code、RO-data、RW-data、ZI-data数据段
- 详解STM32编译后Code-RO-data-RW-data-ZI-data
- keil中的Code_RO-data_RW-dat_ZI-dat
- 用KEIL编写C语言代码,编译过后会出现形如:Program Size: data=13.0 xdata=0 code=417
- 关于Keil编译后Code RO RW ZI !
- Keil编译后的Code,RO,RW,ZI分别表示什么以及和芯片Flash、SRAM的对应关系
- Keil-MDK查看代码量,RAM时候用情况Code;RO-data;RW-data;ZI-data的分析
- 详解STM32编译后Code-RO-data-RW-data-ZI-data
- Keil中的Code,RO,RW,ZI分别表示什么?