android app运行的时候偶尔会遇到加载so文件的问题,譬如 java.lang.UnsatisfiedLinkError: JNI_ERR returned from JNI_OnLoad in "/data/app-lib/xxx/xxx.so"
今天遇到这种问题时,我按照网上的资料进行如下检查:
- 检查对应编译目录lib下有没有对应so文件;
- 检查对应module下的 build.gradle 没有如下条件
sourceSets { main { jniLibs.srcDirs = ['libs'] } }
我代码里上面1,2条件都满足,但仍然会有如题的exception。
捣鼓半天到最后才发现是混淆的问题,就是加载so文件的java代码被混淆了,导致加载时的文件的名字被改动了,没有加载到正确的so文件。
所以上面的检查步骤我觉得还应再加上一条:
3. 如果是“允许混淆"的"release"编译模式下,需要检查”加载so文件的java目录“是否加入混淆文件“proguard-rules.pro“, 譬如
-keep class tv.xxx.player.** { *; }
我今天的so加载问题就是在混淆proguard-rules.pro文件中加入对应的java文件就解决了。