linux设备堆栈大小限制

问题情景:

在设备运行过程中,进程在执行一函数(function_B)时崩溃了。添加打印信息发现,进程不是由于段错误退出,且在执行到function_A后,并没有进入B函数(在B函数第一行添加打印,未输出)执行,然后进程死亡。

问题原因:

C语言程序执行时会先检查函数的堆栈,linux系统会有一个默认的堆栈大小限制,在B函数中,由于一个数组分配空间过大(2M),栈空间大小超出了限制,不能执行,因此程序挂掉。

linux修改线程默认栈空间大小方法:

在/etc/profile 的最后面添加ulimit -s unlimited 保存,source /etc/profile使修改文件生效

linux查看修改线程默认栈空间大小 :ulimit -s

1、通过命令 ulimit -s 查看linux的默认栈空间大小,默认情况下 为10240 即10M

2、通过命令 ulimit -s 设置大小值 临时改变栈空间大小:ulimit -s 102400, 即修改为100M

3、可以在/etc/rc.local 内 加入 ulimit -s 102400 则可以开机就设置栈空间大小

4、在/etc/security/limits.conf 中也可以改变栈空间大小:

soft stack 102400

重新登录,执行ulimit -s 即可看到改为102400 即100M

解决方法

分析此函数发现,数组用来存储sql语句查询出的数据的,然后遍历数组并拷贝,将数据输出。
由于数据过多,数组大小与其他局部变量占用空间超过2M,导致所需栈空间超出限制
现更改为查询到一条数据时就输出信息,不用中间数组存储,节约栈空间资源。

注意:

类似的事件,在读取文件时也可能发生,尽量不要在读完所有数据后,存到数组中然后处理,避免文件内容太多时,需要一个大数组存储,应该读一行就处理一行。

你可能感兴趣的:(linux,C语言)