linux下c程序进程地址空间分布

进程地址空间中典型的存储区域分配情况:
这里写图片描述
从图中看出,从低地址到高地址分别为:代码段、(初始化)数据段、(未初始化)数据段(BSS)、堆、栈、命令行参数和环境变量
堆向高内存地址生长
栈向低内存地址生长
A代码段:这是由cpu执行的机器指令部分。通常,代码段是可共享的,所以即使是经常执行的程序(如文本编辑程序、C编译程序、shell等)在存储器中也只需要有一个副本,另外,代码段常常是只读的,以防止程序由于意外事故而修改器自身的指令。
B(初始化)数据段:通常将此段称为数据段,它包含了程序中需赋初值的变量。例如,C程序中任何函数之外的说明:
  int maxcount = 99;(全局变量)
C(未初始化)数据段(bss):通常将此段称为bss段,这一名称来源于早期汇编程序的一个操作,意思是”block started by symbol”,在程序开始执行之前,内核将此段初始化为0。函数外的说明:
  long sum[1000];
此变量存放在非初始化数据段中。
D堆:通常在堆中进行动态存储分配。由于历史上形成的惯例,堆位于非初始化数据段顶和栈底之间。
E栈:自动变量以及每次函数调用时所需保存的信息都存放在此段中。每次函数调用时,其返回地址、以及调用者的环境信息(例如某些机器寄存器)都存放在栈中。然后,新被调用的函数在栈上为其自动和临时变量分配存储空间。通过以这种方式使用栈,C函数可以递归调用。
代码:

#include<stdio.h>
#include<stdlib.h>

int bss_var;
int data_var0 = 1;
int main()
{
    printf("Test location:\n");
    printf("\tAddress of main(Code Segment):%p\n",main);
    printf("_____________________________________\n");
    int stack_var0 = 2;
    printf("Stack location:\n");
    printf("\tInitial end of stack:%p\n",&stack_var0);
    int stack_var1 = 3;
    printf("\tNew end of stack:%p\n",&stack_var1);
    printf("_____________________________________\n");
    printf("Data location:\n");
    printf("\tAddress of data_var(Data Segment):%p\n",&data_var0);
    static int data_var1 = 4;
    printf("\tNew end of data_var(Data Segment):%p\n",&data_var1);
    printf("_____________________________________\n");
    printf("BSS location:\n");
    printf("\tAddress of bss_var:%p\n",&bss_var);
    printf("_____________________________________\n");
    printf("Heap location:\n");
    char *p = (char *)malloc(10);
    printf("\tAddress of head_var:%p\n",p);
    return 0;
}

执行结果:
这里写图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值