- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
C语言程序编译的内存分配:
1.栈区(stack) --编译器自动分配释放,主要存放函数的参数值,局部变量值等;
2.堆区(heap) --由程序员分配释放;
3.全局区或静态区 --存放全局变量和静态变量;程序结束时由系统释放,分为全局初始化区和全局未初始化区;
4.字符常量区 --常量字符串放与此,程序结束时由系统释放;
5.程序代码区--存放函数体的二进制代码
例: //main.c
int a=0; //全局初始化区
char *p1; //全局未初始化区
void main()
{
int b; //栈
char s[]=bb; //栈
char *p2; //栈
char *p3=123; //其中,“123\0”常量区,p3在栈区
static int c=0; //全局区
p1=(char*)malloc(10); //10个字节区域在堆区
strcpy(p1,123); //123\0在常量区,编译器 可能 会优化为和p3的指向同一块区域
}
一个C程序占用的内存可分为以下几类:(一) 栈这是由编译器自动分配和释放的区域。主要存储函数的参数,函数的局部变量等。当 一个函数开始执行时,该函数所需的实参,局部变量就推入栈中,该函数执行完毕 后,之前进入栈中的参数和变量等也都出栈被释放掉。它的运行方式类似于数据结构 中的栈。(二) 堆这是由程序员控制分配和释放的区域,在C里,用malloc()函数分配的空间就存在于堆 上。在堆上分配的空间不像栈一样在某个函数执行完毕就自动释放,而是一直存在于 整个程序的运行期间。当然,如果你不手动释放(free()函数)这些空间,在程序运行 结束后系统也会将之自动释放。对于小程序来说可能感觉不到影响的存在,但对于大 程序,例如一个大型游戏,就会遇到内存不够用的问题了。(三) 全局区C里的全局变量和静态变量存储在全局区。它们有点像堆上的空间,也是持续存在于程序的整个运行期间,但不同的是,他们是由编译器自己控制分配和释放的。(四) 文字常量区例如char *c = “123456”;则”123456”为文字常量,存放于文字常量区。也由编译器 控制分配和释放。(五) 程序代码区存放函数体的二进制代码。2. 例子(一)int a = 0; //全局区void main(){int b; //栈char s[] = abc; //s在栈,abc在文字常量区char *p1,*p2; //栈char *p3 = 123456; //123456在常量区,p3在栈上static int c =0; //全局区p1 = (char *)malloc(10); //p1在栈,分配的10字节在堆p2 = (char *)malloc(20); //p2在栈,分配的20字节在堆strcpy(p1, 123456); //123456放在常量区//编译器可能将它与p3所指向的123456优化成一个地方。}3. 例子(二)//返回char型指针char *f(){//s数组存放于栈上char s[4] = {1,2,3,0};return s; //返回s数组的地址,但程序运行完s数组就被释放了}void main(){char *s;s = f();printf (%s, s); //打印出来乱码。因为s所指向地址已经没有数据}
还有就是函数调用时会在栈上有一系列的保留现场及传递参数的操作。 栈的空间大小有限定,vc的缺省是2M。栈不够用的情况一般是程序中分配了大量数组和递归函数层次太 深。有一点必须知道,当一个函数调用完返回后它会释放该函数中所有的栈空间。栈是由编译器自动管 理的,不用你操心。 堆是动态分配内存的,并且你可以分配使用很大的内存。但是用不好会产生内存泄漏。 并且频繁地malloc和free会产生内存碎片(有点类似磁盘碎片),因为c分配动态内存时是寻找匹配的 内存的。而用栈则不会产生碎片。 在栈上存取数据比通过指针在堆上存取数据快些。 一般大家说的堆栈和栈是一样的,就是栈(stack),而说堆时才是堆heap. 栈是先入后出的,一般是由高地址向低地址生长。 转载的另外一篇: 堆(heap)和栈(stack)是C/C++编程不可避免会碰到的两个基本概念。首先,这两个概念都可以在讲数据 结构的书中找到,他们都是基本的数据结构,虽然栈更为简单一些。 在具体的C/C++编程框架中,这两个概念并不是并行的。对底层机器代码的研究可以揭示,栈是机器系 统提供的数据结构,
您可能关注的文档
- C1.3.3-1-1环境保护管理制度(2009修订)C1.3.3-1-1环境保护管理制度(2009修订).doc
- C12025(95分)C12025(95分).docx
- C1施工管理资料目录C1施工管理资料目录.doc
- C2-3商务楼竣工验收评估报告0716改C2-3商务楼竣工验收评估报告0716改.doc
- C20喷射混凝土配合比试配步骤(协和)C20喷射混凝土配合比试配步骤(协和).doc
- C20混凝土路肩技术交底C20混凝土路肩技术交底.doc
- C25喷射混凝土配合比设计说明C25喷射混凝土配合比设计说明.doc
- C25水泥混凝土配合比设计报告C25水泥混凝土配合比设计报告.doc
- C25砼路面配合比设计C25砼路面配合比设计.doc
- C30砼配合比(35~50)[12.2C30砼配合比(35~50)[12.2.doc
- 圆的概念与垂径定理-能力强化-记忆1(教师版)-初中数学中考专项《几何模型密训营》专题突破.pdf
- 圆的概念与垂径定理-能力强化-评判1(教师版)-初中数学中考专项《几何模型密训营》专题突破.pdf
- 圆的概念与垂径定理-能力强化-评判1(学生版)-初中数学中考专项《几何模型密训营》专题突破.pdf
- 圆的概念与垂径定理-能力强化-运用1(学生版)-初中数学中考专项《几何模型密训营》专题突破.pdf
- 2022秋季新版教科版五年级上册科学(全册)教学(期末知识复习知识梳理知识归纳)(最全).doc
- 2022秋季教科版五年级科学上册期末知识复习知识梳理知识归纳(全册)(最全).doc
- BIM+VR虚拟仿真实训室场景应用中心建设方案 (最全).doc
- IATF 16949 质量管理体系逻辑链条解读.docx
- IATF 16949 条款4.0 组织环境 专业解析及汽车零部件行业应用.docx
- 2024-2025学年七年级数学下学期期中模拟卷(人教版2024,测试范围:相交线与平行线、实数、平面直角坐标系)(原卷版).pdf
文档评论(0)