翻译  有关内存分段 收藏

 

寄存器是特殊形式的内存,嵌入到处理器内部。

         每个进程需要访问内存中属于自身的区域,因此,可将内存划分成小的段,按需分发给进程。寄存器用来存储和跟踪进程当前维护的段。偏移寄存器(Offset Registers)用来跟踪关键的数据放在段中的位置。

       在进程被载入内存中时,基本上被分裂成许多小的节(section)。我们比较关注的是6个主要的节:

(1) .text 节

    .text 节基本上相当于二进制可执行文件的.text部分,它包含了完成程序任务的机器指令。该节标记为只读,如果发生写操作,会造成segmentation fault。在进程最初被加载到内存中开始,该节的大小就被固定。

(2).data 节

  .data节用来存储初始化过的变量,如:int a =0 ; 该节的大小在运行时固定的。

(3).bss 节

栈下节(below stack section ,即.bss)用来存储为初始化的变量,如:int a; 该节的大小在运行时固定的。

(4) 堆节

堆节(heap section)用来存储动态分配的变量,位置从内存的低地址向高地址增长。内存的分配和释放通过malloc() 和 free() 函数控制。

(5) 栈节

栈节(stack section)用来跟踪函数调用(可能是递归的),在大多数系统上从内存的高地址向低地址增长。同时,栈这种增长方式,导致了缓冲区溢出的可能性。

(6)环境/参数节

     环境/参数节(environment/arguments section)用来存储系统环境变量的一份复制文件,进程在运行时可能需要。例如,运行中的进程,可以通过环境变量来访问路径、shell 名称、主机名等信息。该节是可写的,因此在格式串(format string)和缓冲区溢出(buffer overflow)攻击中都可以使用该节。另外,命令行参数也保持在该区域中。进程的内存空间如下所示:

 

发表于 @ 2007年12月22日 23:44:00 | 评论( loading... ) | 编辑| 举报| 收藏

旧一篇:(转载)软件史上最伟大的十大程序员(图文) | 新一篇:统计程序执行时间总结

  • 发表评论
  • 评论内容:
  •  
Copyright © msccao
Powered by CSDN Blog