- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
语言程序编译空间分配
C语言程序编译空间分配
0500 20 0OTHER 124 048 7819 01 0星级BLOG 0yjvijfhvk#FFFFFF# no-repeat _blank 02010-08-22 22:10:52 02010-12-12 19:00:32 02010-12-25 22:18:31 02010-08-25 00:12:50 02010-08-24 23:40:46 02010-08-29 21:58:21 02010-08-29 13:44:47 02010-08-18 23:50:04 02010-08-25 00:11:34 02010-08-18 23:51:00 02010-09-27 20:50:30,,,,,,,,,,,,,,,,,,,,,,,,,,,, 02011-05-27 22:53:14 2011-05-27 22:53:14 10 0\r\n C语言程序编译的内存分配,堆与栈的区别\r\n
\r\n
\r\n
\r\n C语言程序编译的内存分配:\r\n 1.栈区(stack)--编译器自动分配释放,主要存放函数的参数值,局部变量值等;\r\n 2.堆区(heap)--由程序员分配释放;\r\n 3.全局区或静态区--存放全局变量和静态变量;程序结束时由系统释放,分为全局初始化区和全局未初始化区;\r\n 4.字符常量区--常量字符串放与此,程序结束时由系统释放;\r\n 5.程序代码区--存放函数体的二进制代码\r\n
\r\n
例://main.c\r\n int a=0;//全局初始化区\r\n char*p1;//全局未初始化区\r\n void main()\r\n
\r\n int b;//栈\r\n char s=\bb\;//栈\r\n char*p2;//栈\r\n char*p3=\123\;//其中,123\0常量区,p3在栈区\r\n static int c=0;//全局区\r\n p1=(char*)malloc(10);//10个字节区域在堆区\r\n strcpy(p1,\123\);//\123\0\在常量区,编译器可能会优化为和p3的指向同一块区域\r\n
\r\n
\r\n
\r\n
一个C程序占用的内存可分为以下几类:
(一)栈
这是由编译器自动分配和释放的区域。主要存储函数的参数,函数的局部变量等。当
一个函数开始执行时,该函数所需的实参,局部变量就推入栈中,该函数执行完毕
后,之前进入栈中的参数和变量等也都出栈被释放掉。它的运行方式类似于数据结构
中的栈。
(二)堆
这是由程序员控制分配和释放的区域,在C里,用malloc()函数分配的空间就存在于堆
上。在堆上分配的空间不像栈一样在某个函数执行完毕就自动释放,而是一直存在于
整个程序的运行期间。当然,如果你不手动释放(free()函数)这些空间,在程序运行
结束后系统也会将之自动释放。对于小程序来说可能感觉不到影响的存在,但对于大
程序,例如一个大型游戏,就会遇到内存不够用的问题了。
(三)全局区
C里的全局变量和静态变量存储在全局区。它们有点像堆上的空间,也是持续存在于程
序的整个运行期间,但不同的是,他们是由编译器自己控制分配和释放的。
(四)文字常量区
例如char*c=;则为文字常量,存放于文字常量区。也由编译器
控制分配和释放。
(五)程序代码区
存放函数体的二进制代码。
2.例子(一)
int a=0;//全局区
void main()
{
int b;//栈
char s=\abc\;//s在栈,\abc\在文字常量区
char*p1,*p2;//栈
char*p3=\\;//\\在常量区,p3在栈上
static int c=0;//全局区
p1=(char*)malloc(10);//p1在栈,分配的10字节在堆
p2=(char*)malloc(20);//p2在栈,分配的20字节在堆
strcpy(p1,\\);//\\放在常量区
//编译器可能将它与p3所指向的\\优化成一个地方。
}
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所指向地址已经没有数据
}
\r\n
还有就是函数调用时会在栈上有一系列的保留现场及传递参数的操作。
栈的空间大小有限定,vc的缺省是2M。栈不够用的情况一般是程序中分配了大量数组和递归函数层次太
深。有一点必须知道,当一个函数调用完返回后它
文档评论(0)