Andriod 出现SIGILL 异常

我们项目中导入了第三方的library时,有的手机会报SIGILL(ILL_ILLOPC)异常,这时候我们需要警觉是否匹配部分手机的cpu架构。

例如导入faceId的类库IDCardLib

Andriod 出现SIGILL 异常_第1张图片


可见他的lib里是支持arm64-v8a架构的,因此在项目的config.gradle文件的abiFilters中加入'arm64-v8a'


这样运行时,就不会出现异常了。


illegal instruction介绍:

SIG是信号名的通用前缀。ILL是 illegal instruction(非法指令) 的缩写。SIGILL 是当一个进程尝试执行一个非法指令时发送给它的信号。
可执行程序含有非法指令的原因,一般也就是cpu架构不对,编译时指定的march和实际执行的机器的march不同。这种情况,因为工具链一样,连接脚 本一样,所以可执行程序可以执行,不会发生exec format error。但是会包含一些不兼容的指令。还有另外一种可能,就是程序的执行权限不够,比如在目态下运行的程序只能执行非特权指令,一旦CPU遇到特权指 令,将产生illegal instruction错误。
SIG是信号名的通用前缀。ILL是 illegal instruction(非法指令) 的缩写。SIGILL 是当一个进程尝试执行一个非法指令时发送给它的信号。

可执行程序含有非法指令的原因,一般也就是cpu架构不对,编译时指定的march和实际执行的机器的march不同。这种情况,因为工具链一样,连接脚 本一样,所以可执行程序可以执行,不会发生exec format error。但是会包含一些不兼容的指令。还有另外一种可能,就是程序的执行权限不够,比如在目态下运行的程序只能执行非特权指令,一旦CPU遇到特权指 令,将产生illegal instruction错误。


更多关于CPU架构的知识请看:http://blog.csdn.net/ouyang_peng/article/details/51168072 (原文链接)


你可能感兴趣的:(Exception)