BSS段:BSS段(bss segment)通常是指用来存放程序中未初始化的全局变量的一块内存区域。BSS是英文Block Started by Symbol的简称。BSS段属于静态内存分配。 
  
数据段:数据段(data segment)通常是指用来存放程序中已初始化的全局变量的一块内存区域。数据段属于静态内存分配。 
  
代码段:代码段(code segment/text segment)通常是指用来存放程序执行代码的一块内存区域。这部分区域的大小在程序运行前就已经确定,并且内存区域通常属于只读, 某些架构也允许代码段为可写,即允许修改程序。在代码段中,也有可能包含一些只读的常数变量,例如字符串常量等。 
  
堆(heap):堆是用于存放进程运行中被动态分配的内存段,它的大小并不固定,可动态扩张或缩减。当进程调用malloc等函数分配内存时,新分配的内存就被动态添加到堆上(堆被扩张);当利用free等函数释放内存时,被释放的内存从堆中被剔除(堆被缩减) 
  
栈(stack):栈又称堆栈,是用户存放程序临时创建的局部变量,也就是说我们函数括弧“{}”中定义的变量(但不包括static声明的变量,static意味着在数据段中存放变量)。除此以外,在函数被调用时,其参数也会被压入发起调用的进程栈中,并且待到调用结束后,函数的返回值也会被存放回栈中。由于栈的先进先出特点,所以栈特别方便用来保存/恢复调用现场。从这个意义上讲,我们可以把堆栈看成一个寄存、交换临时数据的内存区。


一个程序本质上都是由 bss段、data段、text段三个组成的。

这样的概念,不知道最初来源于哪里的规定,但在当前的计算机程序设计中是很重要的一个基本概念。而且在嵌入式系统的设计中也非常重要,牵涉到嵌入式系统运行时的内存大小分配,存储单元占用空间大小的问题。

在采用段式内存管理的架构中(比如intel的80x86系统),bss段(Block Started by Symbol segment)通常是指用来存放程序中未初始化的全局变量的一块内存区域,一般在初始化时bss 段部分将会清零。bss段属于静态内存分配,即程序一开始就将其清零了。

比如,在C语言之类的程序编译完成之后,已初始化的全局变量保存在.data 段中,未初始化的全局变量保存在.bss 段中。
    在《Programming ground up》里对.bss的解释为:There is another section called the .bss. This section is like the data section, except that it doesn’t take up space in the executable.
    text和data段都在可执行文件中(在嵌入式系统里一般是固化在镜像文件中),由系统从可执行文件中加载;而bss段不在可执行文件中,由系统初始化。

 
 

1 前言

    一直以来对于ARM体系中所描述的RO,RW和ZI数据存在似是而非的理解,这段时间对其仔细了解了一番,发现了一些规律,理解了一些以前书本上有的但是不理解的东西,我想应该有不少人也有和我同样的困惑,因此将我的一些关于RO,RW和ZI的理解写出来,希望能对大家有所帮助。
    要了解RO,RW和ZI需要首先了解以下知识。

2 ARM程序的组成

    此处所说的“ARM程序”是指在ARM系统中正在执行的程序,而非保存在ROM中的bin映像(image)文件,这一点清注意区别。
             一个ARM程序包含3部分:RO,RW和ZI
             RO是程序中的指令和常量
             RW是程序中的已初始化变量
             ZI是程序中的未初始化的变量

 由以上3点说明可以理解为:
             RO就是readonly,
             RW就是read/write,
             ZI就是zero

3 ARM映像文件的组成

   所谓ARM映像文件就是指烧录到ROM中的bin文件,也成为image文件。以下用Image文件来称呼它。
            Image文件包含了RO和RW数据。
            之所以Image文件不包含ZI数据,是因为ZI数据都是0,没必要包含,只要程序运行之前将ZI数据所在的区域一律清零即可。包含进去反而浪费存储空间。
            Q:为什么Image中必须包含RO和RW?
            A:因为RO中的指令和常量以及RW中初始化过的变量是不能像ZI那样“无中生有”的。

4 ARM程序的执行过程

    从以上两点可以知道,烧录到ROM中的image文件与实际运行时的ARM程序之间并不是完全一样的。因此就有必要了解ARM程序是如何从ROM中的image到达实际运行状态的。
            实际上,RO中的指令至少应该有这样的功能:
            1. 将RW从ROM中搬到RAM中,因为RW是变量,变量不能存在ROM中。
            2. 将ZI所在的RAM区域全部清零,因为ZI区域并不在Image中,所以需要程序根据编译器给出的ZI地址及大小来将相应得RAM区域清零。ZI中也是变量,同理:变量不能存在ROM中
            在程序运行的最初阶段,RO中的指令完成了这两项工作后C程序才能正常访问变量。否则只能运行不含变量的代码。

最新文章

  1. Jass 技能模型定义(—):半人马酋长的反击光环
  2. alert()与console.log()的区别
  3. dex文件格式一
  4. 几种方式实现Javaweb页面跳转
  5. pytessact 出现Error2错误
  6. 类型安全且自动管理内存的返回 std::string 的 sprintf 实现
  7. Hadoop 2.6.0集群搭建
  8. js匀速运动停止条件
  9. 机器学习总结(八)决策树ID3,C4.5算法,CART算法
  10. wap2app(一)-- 网站快速打包成app
  11. java date总结
  12. 表格重新加载 where 携带上次值问题
  13. 关于redis中SDS简单动态字符串
  14. stm32 硬件错误
  15. javaweb笔记—01(编程英语、常识、Tomcat配置问题)
  16. 部署phpmyadmin登录不进去
  17. IDEA 中的一些概念变化
  18. 折射向量计算(Refraction Vector Calculation)
  19. Spring MVC面试整理
  20. 由JDK源码学习ArrayList

热门文章

  1. js巧用apply方法实现数组最值以及合并
  2. Codeforces 722D. Generating Sets
  3. css实现div的高度填满剩余空间
  4. 一个简单的JAVA C/S多线程应用
  5. 常用SVN命令
  6. ROS学习笔记(八)——ROSTOPIC
  7. IntelliJ IDEA 2016
  8. js--内容判断(依赖于jq)
  9. 奇淫绝技:Mysql报错注入利用总结分享
  10. 点击空白处div消失的方法