网站大量收购独家精品文档,联系QQ:2885784924

C语言程序编译空间分配C语言程序编译空间分配.doc

C语言程序编译空间分配C语言程序编译空间分配.doc

  1. 1、本文档共5页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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++编程框架中,这两个概念并不是并行的。对底层机器代码的研究可以揭示,栈是机器系 统提供的数据结构,

您可能关注的文档

文档评论(0)

ptaosqi + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档