java.lang.UnsatisfiedLinkError

异常信息

显然,这是由于读取不到so文件导致的异常。

我尝试了如下方法:

  1. 检查了jniLibs目录下的文件结构和so文件,都稳稳的躺在那儿;
    jniLibs目录结构
  2. 试图使用如下方式重新指定目录,依然无果;
sourceSets { 
      main {
            jniLibs.srcDirs = ['libs'] 
      } 
}
  1. 请教提供so文件的开发同学是否与targetSdkVersion等有关系,并且试图配置了和他们一样的version
  2. Clean ProjectRebuild Project
  3. 反编译查看apk中的libs目录下确实也存在so文件

然而,并无卵用!

奇怪的是这个异常在真机(OnePlus2,HUAWEI MATE8)上有,而在模拟器上却安然无恙。

于是乎,查看到OnePlus2的CPU架构CPU_ABI=arm64-v8a。翻阅到一篇文章描述到:

对于一个 cpuarm64-v8a架构的手机,它运行app时,进入jnilibs去读取库文件时,先看有没有arm64-v8a文件夹:
如果没有该文件夹,去找armeabi-v7a文件夹,如果没有,再去找armeabi文件夹,如果连这个文件夹也没有,就抛出异常
如果有arm64-v8a文件夹,那么就去找特定名称的.so文件,注意:如果没有找到,不会再往下(armeabi-v7a文件夹)找了,而是直接抛出异常

如上图jniLibs目录结构,本地并不存在arm64-v8a文件夹,反编译apk后发现竟然存在此目录,显然是由于其他aar的引入会生成此目录,用于存放其相关so文件

过滤掉此目录:

defaultConfig { 
      //省略其余配置 
      ndk {
            //这句话的意思是指定ndk需要兼容的架构,其余文件夹so文件全部过滤掉
            abiFilters "armeabi", "armeabi-v7a", "x86" 
      }
}```

这么个问题,两天的光景没了!蓝瘦,香菇。

[关于abiFilters的使用](http://blog.csdn.net/wove55678/article/details/52313208)
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容