jni应用运行时抛出在system/lib64下找不到app使用的so库

最近在进行jni的app开发时,因为要用到第三方的so库,app安装在android8.0的平台上,且平台芯片是64位的。刚开始只是在jniLibs下创建了armeabi-v7a, 然后在gradle-properties文件中添加android.usedeprecatedNdk=true,并在build.gradle文件中添加

ndk{
            abiFilters 'armeabi-v7a'
}

,这样androidStudio就只编译出了armeabi-v7a的so库,将该so库拷贝到设备的system/lib下面。

但是运行app一下就挂掉了,log *:E即可看到在system/lib64, vendor/lib64...下找不到对应的so库,刚开始以为上面的配置就可以限制应用只用32位的so库了,实际上64位芯片的机器仍然会去寻找64位的so库。真实头疼,没办法,只能老老实实把64位的第三方so库加上(arm64-v8a文件夹),编译出自己的64位so,然后将它拷贝到system/lib64/目录下,测试app可以正常运行。

jni应用运行时抛出在system/lib64下找不到app使用的so库_第1张图片

jni应用运行时抛出在system/lib64下找不到app使用的so库_第2张图片

jni应用运行时抛出在system/lib64下找不到app使用的so库_第3张图片

 

 

最后编译出的so库。

jni应用运行时抛出在system/lib64下找不到app使用的so库_第4张图片

你可能感兴趣的:(jni应用运行时抛出在system/lib64下找不到app使用的so库)