1.序言
今天某同事突然问我:我在Linux上写了一个测试程序,在函数内部定义了一个很大的数组,一运行就 Segmentation fault.
当时一想肯定是栈溢出了。其实这样说也不准确,还是决定去看内核代码,其实内核对用户进程是有资源限制的。
2.task_struct
既然是跟进程相关,那么首先得想到进程相关的数据结构task_struct,查找资源限制相关的结构,task_struct里面有这么个结构 struct signal_struct *signal。信号相关里面又包含对资源的限制struct rlimit rlim[RLIM_NLIMITS];
3./proc文件系统
也可以从/proc文件系统查看到进程栈空间大小的限制。
cat /proc/self/limits
NOTE:算一下应该是8M的样子,其实栈空间已经很大了。
如果把局部数组设置成该值,铁定崩溃。
I.后记
出了问题不用怕,去寻根问底就好。总能找到你所需要的答案。