如何查看栈的大小
(2012-06-08 03:46:07)
标签:
的如何杂谈 |
如何查看栈的大小在一个函数调用另外一个函数时,会发生分配栈大小的变化, 这个大小是有编译器控制的吗?
这个和我们常说的系统栈有什么不同? 定义系统栈的code我们能看到吗?栈的变化只是建立函数栈的框架(即ebp),同时给函数局部变量分配线性地址空间(即esp+?),这个不是编译器控制的
直到访问缺页的时候,才会为变量分配物理空间如果是gcc/linux的可执行文件,先用readelf看http://www.teadoctor8.com/:
$ readelf -l /bin/ls
...
Type Offset VirtAddr PhysAddr FileSiz MemSizFlg Align
...
GNU_STACK 0x000000 0x00000000 0x00000000 0x00000 0x00000 RW0x4
...
如果MemSiz为零,则由OS决定栈的大小。
$ ulimit -a | grep stack
stack size (kbyteshttp://www.hnjcjx.net, -s) 8192
可以看到OS设定的值是8MB
编译时改变stack大小的方法:
ld --stack=栈尺寸
或
gcc -Wl,--stack=栈尺寸
例如 gcc -Wl,--stack=0x4000000如果是VC++ 用dumpbin看。
dumpbin /HEADER c:\windows\system32\attrib.exe
...
OPTIONAL HEADER VALUES
...
80000 size of stack reserve
2000 size of stack commit
100000 size of heap reserve
1000 size of heap commit
...
可见VC++给的默认栈空间比较少,VC++v10.0给得要大点。
100000 size of stack reserve
1000 size of stack commit
100000 size of heap reserve
1000 size of heap commit
如果这样就会栈溢出
void foo(void)
{
char stackoverf;
memset(stackoverf, 0xcc, sizeof stackoverf);
}
编译链接时指定栈空间大小
CL /F stack_size
或者
LINK /STACK:stack_size struct rlimit lim;
if(getrlimit(RLIMIT_STACK, &lim) < 0)
{
perror("getrlimit");
exit(1);
}
printf("stack size:%lu\n",lim.rlim_cur);学习。。
这个和我们常说的系统栈有什么不同? 定义系统栈的code我们能看到吗?栈的变化只是建立函数栈的框架(即ebp),同时给函数局部变量分配线性地址空间(即esp+?),这个不是编译器控制的
直到访问缺页的时候,才会为变量分配物理空间如果是gcc/linux的可执行文件,先用readelf看http://www.teadoctor8.com/:
$ readelf -l /bin/ls
...
Type Offset VirtAddr PhysAddr FileSiz MemSizFlg Align
...
GNU_STACK 0x000000 0x00000000 0x00000000 0x00000 0x00000 RW0x4
...
如果MemSiz为零,则由OS决定栈的大小。
$ ulimit -a | grep stack
stack size (kbyteshttp://www.hnjcjx.net, -s) 8192
可以看到OS设定的值是8MB
编译时改变stack大小的方法:
ld --stack=栈尺寸
或
gcc -Wl,--stack=栈尺寸
例如 gcc -Wl,--stack=0x4000000如果是VC++ 用dumpbin看。
dumpbin /HEADER c:\windows\system32\attrib.exe
...
OPTIONAL HEADER VALUES
...
80000 size of stack reserve
2000 size of stack commit
100000 size of heap reserve
1000 size of heap commit
...
可见VC++给的默认栈空间比较少,VC++v10.0给得要大点。
100000 size of stack reserve
1000 size of stack commit
100000 size of heap reserve
1000 size of heap commit
如果这样就会栈溢出
void foo(void)
{
char stackoverf;
memset(stackoverf, 0xcc, sizeof stackoverf);
}
编译链接时指定栈空间大小
CL /F stack_size
或者
LINK /STACK:stack_size struct rlimit lim;
if(getrlimit(RLIMIT_STACK, &lim) < 0)
{
perror("getrlimit");
exit(1);
}
printf("stack size:%lu\n",lim.rlim_cur);学习。。
前一篇:nat问题!
后一篇:symbian学习第一天

加载中…