C程序的内存分配.ppt_第1页
C程序的内存分配.ppt_第2页
C程序的内存分配.ppt_第3页
C程序的内存分配.ppt_第4页
C程序的内存分配.ppt_第5页
已阅读5页,还剩7页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、CC+程序的内存分配,堆和栈的区别,一、基本概念,1.栈区(stack) 由编译器自动分配、释放 存放函数的参数值、局部变量的值等 类似于数据结构中的栈 2.堆区(heap) 一般由程序员分配、释放, 若程序员不释放,程序结束时可能由OS回收。 与数据结构中的堆不同,分配方式类似于链表,3、初始化数据区/静态数据区(static) 全局变量、静态变量、常量数据的存储 程序结束后由系统释放 4、未初始化区 常量字符串 程序结束后由系统释放 5、代码区 存放CPU执行的机器指令 可共享、只读的,二、例子程序,/main.cpp int a = 0; (全局初始化区) char *p1;(全局未初始

2、化区) main() int b; 栈 char s = abc; 栈 char *p2; 栈,char *p3 = 123456; 1234560在常量区,p3在栈上。 static int c =0; 全局(静态)初始化区 p1 = (char *)malloc(10); p2 = (char *)malloc(20); 分配得来的10和20字节的区域就在堆区 注意 p1, p2本身是在栈中的,strcpy(p1, 123456); 1234560放在常量区,编译器可能会将它与p3所指向的“123456” 优化成一个地方。 free(p1); free(p2); 释放堆空间 ,三、堆和栈的

3、理论知识,3.1、申请方式 栈区(stack) 由系统自动分配 堆区(heap) 需要程序员自己申请,并指明大小。 在C中malloc函数,在C+中用new运算符,3.2、申请后系统的响应 栈区(stack):只要栈的剩余空间大于所申请空间,系统将为程序提供内存,否则将报异常提示栈溢出。 堆区(heap): 记录空闲内存地址的链表 遍历该链表 大于所申请空间的堆结点 该结点的空间分配给程序,3.3 申请大小的限制 栈区(stack) 栈是向低地址扩展的数据结构,是一块连续的内存区域 栈顶的地址和栈的最大容量是系统预先规定 申请的空间超过栈的剩余空间,溢出 堆区(heap) 堆是向高地址扩展的数据结构,是不连续的内存区域 受限于计算机系统中有效的虚拟内存,3.4堆和栈中的存储方式 (1).栈区(stack) 进栈:主函数中后的下一条指令(函数调用语句的下一条可执行语句)的地址参数(由右往左入栈的)函数中的局部变量(注意静态变量是不入栈的) 出栈 :局部变量参数主函数中的下一条指令 (2).堆区(heap) 在堆的头部用一个字节存放堆的大小 由程序员安排,四、小结:栈和堆的区别,(1)

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论