《带你学C带你飞学习笔记》—— SE39C语言的内存分布(课后题未完成)

知识点回顾

1. C语言的内存布局规律
在这里插入图片描述
可以看到局部变量的地址是占据高地,接着是malloc函数的动态内存空间,然后是全局变量和静态局部变量。
不过这两者都需要区分是否有已经初始化,已经初始化的放一块,未初始化的放一块,并且未初始化的地址要比初始化的要更高一些。接着下来是字符串常量,最后是函数的地址。

2. 典型的C语言程序的内存空间划分
在这里插入图片描述
根据内存地址从低到高分别划分为:

  1. 代码段(Text segment)
  2. 数据段(Initialized data segment)
  3. BSS段(Bss segment/Unintialized data segment)
  4. 栈(Stack)
  5. 堆(Heap)

3. 代码段(Text segment)

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

4. 数据段(data segment)

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

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

6. 堆
前面我们学习了动态内存管理函数,使用他们申请的内存空间就是分配在这个堆里边。
所以堆是用于存放进程中被动态分配的内存段,它的大小并不固定,可动态扩展或缩小。

7. 栈
栈 是函数执行的内存区域,通常和堆共享一片区域。

8. 堆和栈的区别
堆和栈则是C语言运行的最重要的元素,下面我们将其对比

申请方式

  1. 堆是由程序员手动申请
  2. 栈是有系统自动分配
    释放方式
  3. 堆是由程序员手动释放
  4. 栈是有系统自动释放
    生存周期

堆的生存周期由动态申请到程序员主动释放为止,不同函数之间局可以自由访问。
栈的生存周期由函数调用开始到函数返回时结束,函数之间的局部变量不能互相访问。

发展方向
堆和其他区段一样,都是从低地址向高地址。
栈则相反,是由高地址向低地址。

测试题

0. 根据 C 语言的内存布局规律,通常局部变量和全局变量哪一个的地址更小?
答:全局变量的地址更小。

1. 下面代码中,为何两个不同的变量可以存放在同一个地址上?

#include <stdio.h>

void func1(void);
void func2(void);

void func1(void)
{
        int a = 520;
        printf("value of a is %d\n", a);
        printf("addr of a is %p\n", &a);
}

void func2(void)
{
        int b = 880;
        printf("value of b is %d\n&#
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值