Android studio ndk:第三方so库引用的坑

着手开发新的项目,因为要依赖第三方手环的SDK,是个aar包,这个SDK里面引用了so库。

刚开始调用的时候报了这个错误:couldn’t find “libCommand.so

2019-01-03 11:26:19.575 18023-18023/com.lepu.iwown E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.lepu.iwown, PID: 18023
    java.lang.UnsatisfiedLinkError: dalvik.system.PathClassLoader[DexPathList[[zip file "/data/app/com.lepu.iwown-xwIWej6Uien1cnjsNLtApg==/base.apk"],nativeLibraryDirectories=[/data/app/com.abc.abc-xwIWej6Uien1cnjsNLtApg==/lib/arm64, /data/app/com.lepu.iwown-xwIWej6Uien1cnjsNLtApg==/base.apk!/lib/arm64-v8a, /system/lib64, /system/vendor/lib64]]] couldn't find "libCommand.so"
        at java.lang.Runtime.loadLibrary0(Runtime.java:1011)
        at java.lang.System.loadLibrary(System.java:1657)
        at com.mediatek.wearable.LoadJniFunction.<clinit>(Unknown Source:2)
        at com.mediatek.wearable.LoadJniFunction.a(Unknown Source:0)
        at com.mediatek.wearable.WearableConfig.getEpoUrl(Unknown Source:0)
        at com.mediatek.ctrl.epo.EpoDownloadController.<init>(Unknown Source:31)
        at com.mediatek.ctrl.epo.EpoDownloadController.getInstance(Unknown Source:9)
        at com.zeroner.blemidautumn.bluetooth.impl.BleService.onCreate(BleService.java:212)
        at android.app.ActivityThread.handleCreateService(ActivityThread.java:3443)
        at android.app.ActivityThread.-wrap4(Unknown Source:0)
        at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1712)
        at android.os.Handler.dispatchMessage(Handler.java:105)
        at android.os.Looper.loop(Looper.java:176)
        at android.app.ActivityThread.main(ActivityThread.java:6701)
        at java.lang.reflect.Method.invoke(Native Method)
        at com.android.internal.os.Zygote$MethodAndArgsCaller.run(Zygote.java:246)
        at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:783)

导致这个错误产生的原因是:引用的SDK里面对应的jniLibs文件夹,下arm64-v8a下没有对应的so文件。但是其他第三方依赖确有引用arm64-v8a的so库。

所以解决办法就是:

1.让SDK提供者更新SDK版本,提供对应so库
2.在build.gradle文件里,android的defaultConfig里面加上下面这段代码,因为armeabi兼容性最好,几乎所有第三方框架都会有这个so库,我集成的这个也不例外,只有armeabi。只是性能比较差,要是想要兼顾性能,可以选择第一种方法,提供其他平台的so。
		ndk{
			abiFilters "armeabi" //指定要ndk需要兼容的架构(这样其他依赖包里mips,x86,armeabi,arm-v8之类的so会被过滤掉)
		}

就酱!

发布了36 篇原创文章 · 获赞 11 · 访问量 5万+

猜你喜欢

转载自blog.csdn.net/qq_18824545/article/details/85686834