java - Buck - java.lang.UnsatisfiedLinkError : couldn't find "libjni.so". 如何解决?

标签 java android facebook buck

执行命令后出现运行时异常 buck install --run demo_app_android 遵循 this教程和this示例演示

然后控制台显示如下

Installing apk on emulator-5554 (null).
[-] PROCESSING BUCK FILES...FINISHED 0.0s [100%] 🐌  File removed
[-] DOWNLOADING... (0.00 B/S AVG, TOTAL: 0.00 B, 0 Artifacts)
[-] BUILDING...FINISHED 0.8s [100%] (1/1 JOBS, 1 UPDATED, 0 [0.0%] CACHE MISS)
[+] INSTALLING...2.1s
Successfully ran install apk //android:demo-app on 1 device(s)
Starting activity com.facebook.buck.demo/.App...
Successfully ran start activity on 1 device(s)

最后,设备显示一条消息说Buck Demo App has stopped 该应用程序已成功安装,我可以在应用程序列表中看到它,但它无法运行

堆栈跟踪:

E/AndroidRuntime: FATAL EXCEPTION: main
    Process: com.facebook.buck.demo, PID: 7265
    java.lang.UnsatisfiedLinkError: dalvik.system.PathClassLoader[DexPathList[[zip file "/data/app/com.facebook.buck.demo-1/base.apk"],nativeLibraryDirectories=[/data/app/com.facebook.buck.demo-1/lib/x86, /system/lib, /vendor/lib]]] couldn't find "libjni.so"
    at java.lang.Runtime.loadLibrary0(Runtime.java:972)
    at java.lang.System.loadLibrary(System.java:1530)
    at com.facebook.buck.demo.Hello.<init>(Hello.java:13)
    at com.facebook.buck.demo.App.onCreate(App.java:24)
    at android.app.Activity.performCreate(Activity.java:6662)
    at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1118)
    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2599)
    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2707)
    at android.app.ActivityThread.-wrap12(ActivityThread.java)
    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1460)
    at android.os.Handler.dispatchMessage(Handler.java:102)
    at android.os.Looper.loop(Looper.java:154)
    at android.app.ActivityThread.main(ActivityThread.java:6077)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:866)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:756)

设备规范:

  • 原生 Android 模拟器(同样,将其运行到真实设备中,结果相同)
  • 连结 5 API 24

我的电脑:

  • MacBook pro 2012 年中期

注意:此外,此问题已直接报告给 buck repository但还没有给出解决方案

知道如何解决吗?

最佳答案

重复github上的答案:

您需要从 here 安装 Android NDK (版本 10e)并将 ANDROID_NDK_REPOSITORY 设置为解压的 NDK 的位置(有关详细信息,请参阅 buckconfig 部分)。

例如,如果您将 NDK 解压到 ~/tmp/ndk(这样就有一个目录 ~/tmp/ndk/android-ndk-r10e),您需要将 ANDROID_NDK_REPOSITORY 设置为 ~/tmp/ndk

之后删除旧缓存并重建应用程序:

$ buck kill && rm -rf buck-out
$ buck build demo_app_android

关于java - Buck - java.lang.UnsatisfiedLinkError : couldn't find "libjni.so". 如何解决?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44555075/

相关文章:

java - NOTIFICATION_RECEIVER 无法解析为变量

java - Java 中的快速排序 (Stackoverflow)

Android Assets 太慢

facebook - Grails Facebook Spring Security返回null

ios - facebook sdk v4 获取好友帖子的方法

java - 该应用程序在 AVD 上运行良好,但在真实设备上运行不佳

java - 我如何从图库中选择图像并在另一个 Activity 中显示该图像......?

android - 我的模板页面在移动设备上自动缩放

android - 增加 RadioButton 的可点击区域的大小

Facebook Like 评论框被垂直和水平切断