c语言程序执行过程,4.C语言程序执行的流程

本文介绍了程序在内存中的组织和执行流程,包括.data区、.code区、栈和堆的分工。通过一个C语言的例子,阐述了常量、变量、函数如何在内存中分配以及执行过程。同时提到了动态内存分配与释放,如malloc()函数的作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

根据大学所学的知识,我们知道程序都是需要被加载到内存中才能被执行的,而加载到内存当中的数据只能是1或0,即高电频或低电频。那么操作系统如何去识别内存中0011究竟是代码还是数据还是函数或者常量呢?下面我们就简单说一下程序的执行流程。

将编译后的程序加载到操作系统的执行内存中。

操作系统把加载到内存中的数据进行人为的分区,大致分为:

.data区:常量区,存放程序中的所有静态常量,相当于java中的public static 的常量,在C语言中则是通过宏定义(define)声明的常量。

.code区:方法区,存放funcation编译后的声明和实现的描述(其实也是0101).

栈(Stack)空间:程序运行时存放变量的空间,大小由操作系统指定,是一块连续的内存空间,访问速度和效率比Heap要高一些。

堆(Heap)空间:存放对象的一块不连续的内存空间,访问、存储效率比栈稍低。

划分好区域并将对应的数据加载到各自分区后,各个内存分区开始配合工作,举例:

#include

#define PI 3.1415

void swap(int* p, int* q){

int temp;

temp = *p;

*p=*q;

*q = temp;

}

int main(){

int i = 3;

int j = 5;

swap(&i,&j);

printf("i=%d\n",i);

printf("j=%d\n",j);

system("pause");

}

首先操作系统会将define的PI常量放到.data区中,然后从.code区寻找入口函数main()开始执行,

第一行会在栈空间中申请内存空间存放int i=3;

第二行在栈空间中申请内存存放int j=5;

第三行系统会去.code区寻找swap(int* p, int* q)函数并执行,先在栈空间申请内存创建p和q这两个形参,然后申请栈内存创建int temp...当函数执行完之后,栈空间发现p、q、temp已经没有程序在使用了,就会对这个几个局部变量执行出栈操作,腾出内存空间;第四、第五、第六行以此类推。

最后简单说一下堆内存与malloc()函数:动态分配内存空间,也就是向Heap申请一块指定字节大小的内存。例:

#include

char *ptr = (char *)malloc(10);

ptr被存放在栈中,malloc(10)向Heap申请了10个字节的内存空间用来存放字符,当使用完毕之后需手动释放

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值