linux 进程 堆栈大小,如何在linux中确定程序的堆栈大小?

如果你只想要当前的堆栈大小,你可以在main()的顶部声明一个变量,获取它的地址,并将它与在你定义“current”的地方声明的变量的地址进行比较.差异应该是堆栈增长的大致大小.

如果你想知道为堆栈保留了多少内存,你可以检查/ proc / [pid] / maps,它的区域标记为[stack].例如,我的atd流程有:

7fff72a41000-7fff72a56000 rw-p 00000000 00:00 0 [stack]

0175b000-0177c000 rw-p 00000000 00:00 0 [heap]

这给了你一个主意.

当我想知道我的程序使用的最大堆栈大小时,朋友与我分享的一个巧妙的技巧如下.我会在这里介绍它以防有人发现它有用:)

1)在main()的开头附近调用的函数中,使用alloca()或非常长的数组来编写0xDEADBEEF或其他一些不太可能的常量,而不是预期可以使用的堆栈.当小函数返回时,该存储器将被“释放”.

2)在main的末尾,再次使用alloca()来获取一个内存区域并通过它“搜索”你曾经用过的任何魔法常量(你可能会尝试找到64个中的第一个块或者某个东西到跳过可能已经分配但只是从未使用过的内存区域,并且指针所在的位置指示最大堆栈使用情况.

不完美,但它对我正在做的事情很有用!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值