KEIL中如何知道代码的大小以及如何将变量指定在固定的地方

 

 首先看几个名词解释:

(1) Code(inc.Data) : 包含两部分,即代码和数据
- code,即程序代码部分
- inline data. For example, literal pools(文字常量池), and short strings(短字符串)等. 这个一般被忽略,请大家注意!!!
- 代码段,存放程序的代码部分。
(2) RO Data: read-only data,只读的数据
Shows how many bytes are occupied by read-only data. This is in addition to the inline data included in the Code (inc. data) column. 除inline data 之外的所有只读数据。
只读数据段,存放程序中定义的常量。
(3) RW Data: read write data,可读写的数据
Shows how many bytes are occupied by read-write data.
读写数据段,存放初始化为非0值的全局变量。
(4) ZI Data: zero initialized data,零初始化的可读写变量
Shows how many bytes are occupied by zero-initialized data.
0数据段,存放未初始化的全局变量及初始化为0的变量。
存储Size:
RO size: Code + RO_data,表示程序占用Flash空间的大小。
RW size: RW_data + ZI_data,表示运行时占用RAM的大小。
ROM (minimum)size = Code + RO_data + RW_data (即烧/下载程序到FLASH/ROM时,所占用的最小空间)
Total ROM Size (Code + RO Data + RW Data)这样所写的程序占用的ROM的字节总数,也就是说程序所下载到ROM flash 中的大小。为什么Rom中还要存RW,因为掉电后RAM中所有数据都丢失了,每次上电RAM中的数据是被重新赋值的,每次这些固定的值就是存储在Rom中的,为什么不包含ZI段呢,是因为ZI数据都是0,没必要包含,只要程序运行之前将ZI数据所在的区域一律清零即可。包含进去反而浪费存储空间。RAM相当于内存,Flash相当于硬盘。
RAM size: RW Data + ZI Data (即程序运行的时,RAM使用的空间)

通过上述信息可以看出当前代码编译后的总大小为:16088+372+204=16664 字节
16664/1024=16.2734375 K
查看编译后的二进制文件大小

说明理论的计算和实际是相符的。
单片机在上电后默认是从Flash启动,启动之后会将RW段中的RW-data(初始化的全局变量)搬运到RAM中,但不会搬运RO段,即CPU的执行代码从Flash中读取,另外根据编译器给出的ZI地址和大小分配出ZI段,并将这块RAM区域清0.
其中动态内存堆为未使用的RAM空间,应用程序申请和释放的内存块都来自于该空间。
————————————————
版权声明:本文为CSDN博主「qq_511386807」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/qq_20222919/article/details/103779582

 

 从这里可以看出:
芯片IROM大小: 65536个字节

芯片RAM大小: 12x1024 =12288个字节 = 12x1024 byte

查看芯片手册:

 

 

 


 

 可以通过

posted on 2021-04-17 14:50  Ablerry  阅读(1618)  评论(0编辑  收藏  举报