大佬教程收集整理的这篇文章主要介绍了Android – ‘无法加载Foo:findLibrary返回null’,大佬教程大佬觉得挺不错的,现在分享给大家,也给大家做个参考。
我正在尝试运行我的应用程序,但每当调用本机函数时,程序崩溃,我得到以下LogCat …
08-01 09:15:57.448: E/AndroidRuntime(16966): FATAL EXCEPTION: main 08-01 09:15:57.448: E/AndroidRuntime(16966): java.lang.ExceptionInInitializerError 08-01 09:15:57.448: E/AndroidRuntime(16966): at my.eti.commander.MainMenu.initMain(MainMenu.java:241) 08-01 09:15:57.448: E/AndroidRuntime(16966): at my.eti.commander.MainMenu.onCreate(MainMenu.java:81) 08-01 09:15:57.448: E/AndroidRuntime(16966): at android.app.instrumentation.callActivityOnCreate(instrumentation.java:1047) 08-01 09:15:57.448: E/AndroidRuntime(16966): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611) 08-01 09:15:57.448: E/AndroidRuntime(16966): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663) 08-01 09:15:57.448: E/AndroidRuntime(16966): at android.app.ActivityThread.access$1500(ActivityThread.java:117) 08-01 09:15:57.448: E/AndroidRuntime(16966): at android.app.ActivityThread$H.handlemessage(ActivityThread.java:931) 08-01 09:15:57.448: E/AndroidRuntime(16966): at android.os.Handler.dispatchmessage(Handler.java:99) 08-01 09:15:57.448: E/AndroidRuntime(16966): at android.os.Looper.loop(Looper.java:130) 08-01 09:15:57.448: E/AndroidRuntime(16966): at android.app.ActivityThread.main(ActivityThread.java:3683) 08-01 09:15:57.448: E/AndroidRuntime(16966): at java.lang.reflect.Method.invokeNative(Native Method) 08-01 09:15:57.448: E/AndroidRuntime(16966): at java.lang.reflect.Method.invoke(Method.java:507) 08-01 09:15:57.448: E/AndroidRuntime(16966): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:839) 08-01 09:15:57.448: E/AndroidRuntime(16966): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:597) 08-01 09:15:57.448: E/AndroidRuntime(16966): at dalvik.system.NativeStart.main(Native Method) 08-01 09:15:57.448: E/AndroidRuntime(16966): Caused by: java.lang.UnsatisfiedLinkError: Couldn't load RelayAPI: findLibrary returned null 08-01 09:15:57.448: E/AndroidRuntime(16966): at java.lang.Runtime.loadLibrary(Runtime.java:429) 08-01 09:15:57.448: E/AndroidRuntime(16966): at java.lang.System.loadLibrary(System.java:554) 08-01 09:15:57.448: E/AndroidRuntime(16966): at my.eti.commander.RelayAPIModel$NativeCalls.<clinit>(RelayAPIModel.java:432) 08-01 09:15:57.448: E/AndroidRuntime(16966): ... 15 more
这是我的Android.mk文件:
LOCAL_PATH := $(call my-dir) include $(CLEAR_VARS) EXTRA_CFLAGS := -DANDROID LOCAL_MODULE := RelayAPI LOCAL_SRC_FILES := RelayAPI.c include $(BUILD_EXECUTABLE)
这是我的jni文件夹的图片…将只使用RelayAPI,Stringstuff是一个未使用的额外文件.
我将所有本机函数存储在一个单独的类中,以便可以静态调用它们.这不是问题,因为我已经将它们移动了很多但我只是认为这将是我完成它的最佳方式.
public static class NativeCalls { static { System.loadLibrary( "RelayAPI"); } public native static byte InitRelayJava(); public native static void FreeRelayJava(); }
以上是大佬教程为你收集整理的Android – ‘无法加载Foo:findLibrary返回null’全部内容,希望文章能够帮你解决Android – ‘无法加载Foo:findLibrary返回null’所遇到的程序开发问题。
如果觉得大佬教程网站内容还不错,欢迎将大佬教程推荐给程序员好友。
本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。