.1 栈内存申请:栈需要多少空间就给多少空间,不需要通过系统调用去扩展栈顶指针。当进程采取压栈动作后,栈顶指针减少,如果进程访问相应内存时会触发页故障,触发linux内核扩展栈所在的内存空间。由于不涉及系统调用,所以栈段内存的扩展要比对内存扩展更加方便、快捷。
.2 Linux 系统中进程栈段所使用的物理内存是只能增长不会减少的,其大小等于其在运行过程中所使用的最大的栈空间。
.3 栈上申请内存的函数 : alloca,
.4 查看和修改进程栈空间的大小
l 查看: #ulimit –a(stack size, default value is 8192)
l 修改: #ulimit –sxxx
.5 查看和修改线程栈空间的大小
.5.1 在maps中,下面两段内存空间,代表一个线程的栈,如下图:
其中be001000-be200000作为线程的栈空间,而be000000-be001000一个没有任何权限的只读页面,作为一个线程栈的保护页面,隔开了多个线程的栈,当线程的栈溢出时,会触发段错误,从而终止进程。
.5.2 一个线程的栈内存空间为2M,可以通过下面的函数修改线程栈空间:
pthread_attr_setstacksize();
.6 什么导致栈溢出
.6.1 函数调用层次过深
.6.2 局部静态变量体积过大
.7 栈内存从高地址向低地址增长。