问题描述:
有一套C++库,通过JNI被安卓应用调用。
应用中在主线程(UI现场)调用一函数正常,在子线程中调用该函数会导致APP崩溃。APP崩溃时报错信息如下:
E/libsigchain: exiting due to SIG_DFL handler for signal 11
逐步调试后发现在JNI层定义一个400K长度的数组的时候崩溃。在此之前,该函数已定义两个400K大小的数组。将该定义代码注释掉且相关操作用之前定义的数组实现后,该函数可在子线程中调用正常。
现怀疑测试用安卓系统有限制线程使用的内存大小,由于3个400K数组共需1M+内存,超过系统给循序的线程限制,故在定义第三个数组的时候APP崩溃。
问题分析:
参考资料:https://zhuanlan.zhihu.com/p/33562383
调试安卓机版本为9,子线程大小不足1M,JNI定义第3个400K长度的数组的时候,所需内存超过上限,所以APP就崩溃。这里应该和安卓系统剪裁有关,按理内存超限也只是报错退出,不应直接崩溃。由于使用的是定制版本系统,此处不必深究。