局部变量,全局变量?探寻程序上面的栈(STACK)空间的最大值

本文通过一个简单的C语言程序展示了在Cygwin环境下堆栈空间的大小限制。该程序递归地分配局部变量,直到堆栈空间耗尽,以此来估算可用的堆栈空间大小。

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

近日看到有一些与程序、内存的的资料,比较有意思。能够体现全局数据与局部变量的内存关系,我在Cygwin上面跑出来的结果是STACK 的空间只有2M,用完后程序就停止执行了,源代码如下:

filename : DepleteStackSize.c
  #include   

static long STACK_BLOCK_HEADER;  

void depleteStackSpace() {   // declare local variable for booking some STACK spaces.  

 int intVarInStackSpace = 0;   // output the memory offset  

printf("%3.1fM/n", (STACK_BLOCK_HEADER - (long)(&intVarInStackSpace)*1.0)/(1024*1024));   // self recursive   depleteStackSpace();

 

 int main() {   // the first local variable in application memory.  

 int intVarInStackSpace = 0;   // get first local variable address as the STACK block header  

STACK_BLOCK_HEADER = (long)(&intVarInStackSpace);   // perform depletion  

depleteStackSpace();   // out the normal exit message  

printf("normal exit./n"); }

 

在Cygwin中用gcc编译为Win32程序:

[root@sharkwang Temp] # gcc -mno-cygwin -o DepleteStackSize.exe DepleteStackSize.c

 

执行结果摘录如下:
2.0M
2.0M
2.0M  <--- %3.1f格式化后都四舍五入了,所以1.5xxM以上都变成2.0M了
2.0M
2.0M
2.0M
2.0M
2.0M  <--- 到最大空间后程序就停止了,没有看到Normal Exit的输出...
[root@sharkwang Temp] #

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值