C语言-C语言的内存布局规律

本文详细介绍了编程中内存地址划分的四个主要区域:代码段(只读)、数据段(初始化变量)、BSS段(未初始化变量)和堆栈(动态/自动分配)。对比了堆和栈在申请方式、释放机制、生存周期和发展方向上的特点。
摘要由CSDN通过智能技术生成

根据内存地址从低到高分别划分为:

-代码段(Text segment)

-数据段(Initialized dat segment)

-BSS段(Uninitialized data segment)

-栈(Stack)

-堆(Heap)

代码段

代码段通常是指用来存放程序执行代码的一块区域。这部分区域的大小在程序运行前就已经确定,并且内存区域通常属于只读。在代码段中,也有可能包含一些只读的常量变量,例如字符串常量等。

数据段

数据段通常用来存放已经初始化的全局变量和局部静态变量。

BSS段

BSS段通常是指来存放程序中未初始化的全局变量的一块内存区域。BSS是英文Block Started by Symbol的简称,这个区段中的数据在程序运行前将被自动初始化为数字0.

堆是用于存放程序运行中被动态分配的内存段,它的大小并不固定,可动态扩展或缩小。当进程调用malloc等函数分配内存时,新分配的内存就被动态添加到堆上;当利用free等函数释放内存时,被释放的内存从堆中被剔除。

大家平时可能经常听到堆栈这个词,一般指的就是这个栈。栈是函数执行的内存区域,通常和堆共享同一片区域。

堆和栈的区别

申请方式:

-堆由程序员手动申请

-栈由系统自动分配

释放方式:

-堆由程序员手动释放

-栈由系统自动释放到函数返回时结束,函数之间的局部变量不能互相访问

生存周期:

-堆的生存周期由动态申请到程序员主动释放为止,不同函数之间均可自由访问

-栈的生存周期由函数调用开始到函数返回时结束,函数之间的局部变量不能互相访问

发展方向:

-堆和其他区段一样,都是从低地址向高地址发展

-栈则相反,是由高地址向低地址发展

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值