进程内存印象

来源:互联网 发布:淘宝主播底薪一般多少 编辑:程序博客网 时间:2024/06/05 13:34

 Linux下C程序生成主要由四个步骤组成:预编译、编译、汇编、链接。编译器gcc经过 预编译、编译、汇编3个步骤将源程序文件转换成目标文件。如果程序有多个目标文件或程序中使用了库函数,则编译器还需要将所有目标文件及所需的库文件链接起来,最后生成可执行程序。当程序执行时,操作系统将可执行程序复制到内存中,程序转为进程通常需要以下步骤:  

  1. *内核将程序读入内存,为程序分配内存空间;
  2. *内核为该进程保存PID及相应的状态信息,把进程放到运行队列中等待执行。程序转化为进程后就可被操作系统的调度程序执行了。

 进程的内存映像是指内核在内存中如何存放可执行程序文件。在将程序转化为进程的过程中,操作系统将可执行程序从硬盘复制⾄至内存中,其布局如下:

                   

我们只需写个小程序打印一下各个地址就可以验证其正确性了:

#include <stdio.h>#include <stdlib.h>int g_val1 = 0;int g_val2;int main(int argc, char *argv[], char *env[]){printf("code addr: %p\n", main);printf("init var addr: %p\n", &g_val1);printf("uninit var addr: %p\n", &g_val2);char *heap = (char *)malloc(10);printf("heap addr: %p~%p\n", heap, heap + 9);char stack[10];printf("stack addr: %p~%p\n", stack, stack + 9);printf("cmd lind para addr: %p\n", argv);printf("env addr: %p\n", env);free(heap);return 0;}

运行结果:地址依次增长      

  


1 0
原创粉丝点击