gpt4 book ai didi

java - Archos 101 Tablet System.load() 在加载 ndk 库时失败

转载 作者:太空狗 更新时间:2023-10-29 15:20:20 25 4
gpt4 key购买 nike

我有一个同时具有 java 和 NDK(C 代码)的应用程序。此应用程序在 Motorola Xoom 上运行良好,但在 Archos 101 平板电脑上运行失败。

这是有问题的代码:

    static {
try
{
System.loadLibrary("cube");
}
catch (Exception ex)
{
Log.d("scroll", ex.getMessage());
}
}

这是错误的 logcat 转储:

DEBUG/dalvikvm(10198): Trying to load lib /data/data/com.gorglucks.cubendk/lib/libcube.so 0x45497b18
INFO/dalvikvm(10198): Unable to dlopen(/data/data/com.gorglucks.cubendk/lib/libcube.so): Cannot load library: link_image[1995]: failed to link libcube.so
WARN/dalvikvm(10198): Exception Ljava/lang/UnsatisfiedLinkError; thrown during Lcom/gorglucks/cubendk/Main;.<clinit>
WARN/dalvikvm(10198): Class init failed in newInstance call (Lcom/gorglucks/cubendk/Main;)
DEBUG/AndroidRuntime(10198): Shutting down VM
WARN/dalvikvm(10198): threadid=1: thread exiting with uncaught exception (group=0x4001d8a8)
ERROR/AndroidRuntime(10198): FATAL EXCEPTION: main
ERROR/AndroidRuntime(10198): java.lang.ExceptionInInitializerError
ERROR/AndroidRuntime(10198): at java.lang.Class.newInstanceImpl(Native Method)
ERROR/AndroidRuntime(10198): at java.lang.Class.newInstance(Class.java:1429)
ERROR/AndroidRuntime(10198): at android.app.Instrumentation.newActivity(Instrumentation.java:1021)
ERROR/AndroidRuntime(10198): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2577)
ERROR/AndroidRuntime(10198): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
ERROR/AndroidRuntime(10198): at android.app.ActivityThread.access$2300(ActivityThread.java:125)
ERROR/AndroidRuntime(10198): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
ERROR/AndroidRuntime(10198): at android.os.Handler.dispatchMessage(Handler.java:99)
ERROR/AndroidRuntime(10198): at android.os.Looper.loop(Looper.java:123)
ERROR/AndroidRuntime(10198): at android.app.ActivityThread.main(ActivityThread.java:4627)
ERROR/AndroidRuntime(10198): at java.lang.reflect.Method.invokeNative(Native Method)
ERROR/AndroidRuntime(10198): at java.lang.reflect.Method.invoke(Method.java:521)
ERROR/AndroidRuntime(10198): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
ERROR/AndroidRuntime(10198): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
ERROR/AndroidRuntime(10198): at dalvik.system.NativeStart.main(Native Method)
ERROR/AndroidRuntime(10198): Caused by: java.lang.UnsatisfiedLinkError: Library cube not found
ERROR/AndroidRuntime(10198): at java.lang.Runtime.loadLibrary(Runtime.java:461)
ERROR/AndroidRuntime(10198): at java.lang.System.loadLibrary(System.java:557)
ERROR/AndroidRuntime(10198): at com.gorglucks.cubendk.Main.<clinit>(Main.java:24)
ERROR/AndroidRuntime(10198): ... 15 more

我的 C 库 libcube.so 位于 libs/armeabi/libcube.so 中,并显示在 eclipse 项目资源管理器中。我已经通过查看 CubeNDK.apk 验证了这一点。

我还尝试使用以下方式加载库:

System.load("/data/data/com.gorglucks.cubendk/lib/armeabi/libcube.so");

这也失败了。

同样,这在摩托罗拉 Xoom 上运行良好。总的来说,使用这款 Archos 101 非常令人沮丧。 USB 驱动程序不适用于 64 位 PC,但适用于较旧的 32 位 PC。

提前致谢杰瑞

最佳答案

通过消除过程并深入研究文档 android-ndk-r7/docs/STABLE-APIS.html, Assets 管理器在 API 级别 8 (Froyo) 中不可用。

这解决了我的链接问题,但又产生了另一个问题:

如何在不使用 Assets 管理器的情况下从ndk访问 Assets 目录中的文件?

关于java - Archos 101 Tablet System.load() 在加载 ndk 库时失败,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8447668/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com