java.lang.IllegalArgumentException:无法加载本机库

卡尔提克·西瓦姆(Karthik Sivam)

我在项目中使用了纯本地的NDK(本地活动)。当我在Android.mk文件中添加带有.so的预构建静态库时,它工作正常。但是,当我尝试链接Prebuilt共享库时,它显示以下异常:

03-27 16:42:09.982: E/AndroidRuntime(1275): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.irrlicht.example/android.app.NativeActivity}: java.lang.IllegalArgumentException: Unable to load native library: /data/app-lib/com.irrlicht.example-1/libHelloWorldMobile.so

这是我的Android.mk文件:

....

include $(CLEAR_VARS)
LOCAL_C_INCLUDES := /Users/karthi/Android/openal-soft-master/jni/OpenAL/include
LOCAL_MODULE := openal
LOCAL_SRC_FILES := /Users/karthi/Android/openal-soft-master/libs/armeabi/libopenal.so
include $(PREBUILT_SHARED_LIBRARY)

include $(CLEAR_VARS)

LOCAL_MODULE := HelloWorldMobile

LOCAL_CFLAGS := -D_IRR_ANDROID_PLATFORM_ -pipe -fno-exceptions -fno-rtti -fstrict-aliasing

LOCAL_C_INCLUDES := -I ../../include -I /Users/karthi/Android/openal-soft-master/jni/OpenAL/include

LOCAL_SRC_FILES := main.cpp android_tools.cpp game.cpp

LOCAL_LDLIBS := -lEGL -llog -lGLESv1_CM -lGLESv2 -lz -landroid

LOCAL_SHARED_LIBRARIES := openal

include $(BUILD_SHARED_LIBRARY)

在我的AndroidManifest.xml中:

<activity android:name="android.app.NativeActivity"
        android:label="HelloWorldMobile"
        android:launchMode="singleTask"
        android:configChanges="orientation|keyboardHidden"
        android:screenOrientation="landscape"
        android:clearTaskOnLaunch="true">
        <meta-data android:name="android.app.lib_name" android:value="HelloWorldMobile" />                            
        <intent-filter>
                    <action android:name="android.intent.action.MAIN" />

终于在Application.mk中:

APP_PLATFORM := android-18
APP_MODULES  := HelloWorldMobile
APP_STL      := stlport_static

我也尝试过将最后一行替换为

APP_STL := stlport_shared

我还应该怎么做才能将预构建的共享库链接到本机库?我在这里想念什么?任何帮助将不胜感激。

编辑:

03-28 11:57:51.469: D/dalvikvm(824): Debugger has detached; object registry had 1 entries
03-28 11:57:51.479: W/dalvikvm(836): PR_CAPBSET_DROP 1 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.479: W/dalvikvm(836): PR_CAPBSET_DROP 2 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.479: W/dalvikvm(836): PR_CAPBSET_DROP 3 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.479: W/dalvikvm(836): PR_CAPBSET_DROP 4 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.489: W/dalvikvm(836): PR_CAPBSET_DROP 5 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.489: W/dalvikvm(836): PR_CAPBSET_DROP 6 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.489: W/dalvikvm(836): PR_CAPBSET_DROP 7 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.489: W/dalvikvm(836): PR_CAPBSET_DROP 8 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.489: W/dalvikvm(836): PR_CAPBSET_DROP 9 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.489: W/dalvikvm(836): PR_CAPBSET_DROP 10 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.489: W/dalvikvm(836): PR_CAPBSET_DROP 11 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.489: W/dalvikvm(836): PR_CAPBSET_DROP 12 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.489: W/dalvikvm(836): PR_CAPBSET_DROP 13 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.489: W/dalvikvm(836): PR_CAPBSET_DROP 14 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.499: W/dalvikvm(836): PR_CAPBSET_DROP 15 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.499: W/dalvikvm(836): PR_CAPBSET_DROP 16 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.499: W/dalvikvm(836): PR_CAPBSET_DROP 17 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.499: W/dalvikvm(836): PR_CAPBSET_DROP 18 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.499: W/dalvikvm(836): PR_CAPBSET_DROP 19 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.499: W/dalvikvm(836): PR_CAPBSET_DROP 20 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.499: W/dalvikvm(836): PR_CAPBSET_DROP 21 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.499: W/dalvikvm(836): PR_CAPBSET_DROP 22 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.499: W/dalvikvm(836): PR_CAPBSET_DROP 23 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.509: W/dalvikvm(836): PR_CAPBSET_DROP 24 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.509: W/dalvikvm(836): PR_CAPBSET_DROP 25 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.519: W/dalvikvm(836): PR_CAPBSET_DROP 26 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.519: W/dalvikvm(836): PR_CAPBSET_DROP 27 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.519: W/dalvikvm(836): PR_CAPBSET_DROP 28 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.519: W/dalvikvm(836): PR_CAPBSET_DROP 29 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.519: W/dalvikvm(836): PR_CAPBSET_DROP 30 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.529: W/dalvikvm(836): PR_CAPBSET_DROP 31 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.529: W/dalvikvm(836): PR_CAPBSET_DROP 32 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.529: W/dalvikvm(836): PR_CAPBSET_DROP 33 failed: Invalid argument. Please make sure your kernel is compiled with file capabilities support enabled.
03-28 11:57:51.529: D/dalvikvm(836): Not late-enabling CheckJNI (already on)
03-28 11:57:51.539: I/ActivityManager(275): Start proc com.irrlicht.example for activity com.irrlicht.example/android.app.NativeActivity: pid=836 uid=10061 gids={50061, 1015, 1028}
03-28 11:57:51.929: I/ActivityManager(275): Config changes=1480 {1.0 310mcc260mnc en_US ldltr sw320dp w533dp h294dp 240dpi nrml long land finger qwerty/v/v -nav/h s.7}
03-28 11:57:51.954: I/InputReader(275): Reconfiguring input devices.  changes=0x00000004
03-28 11:57:51.954: I/InputReader(275): Device reconfigured: id=0, name='qwerty2', size 480x800, orientation 1, mode 1, display id 0
03-28 11:57:51.969: I/InputReader(275): Reconfiguring input devices.  changes=0x00000004
03-28 11:57:51.969: I/InputReader(275): Device reconfigured: id=0, name='qwerty2', size 480x800, orientation 1, mode 1, display id 0
03-28 11:57:52.529: D/dalvikvm(524): GC_FOR_ALLOC freed 9228K, 70% free 4038K/13380K, paused 192ms, total 216ms
03-28 11:57:52.569: I/dalvikvm-heap(524): Grow heap (frag case) to 10.166MB for 6410576-byte allocation
03-28 11:57:52.690: D/dalvikvm(524): GC_FOR_ALLOC freed 11K, 24% free 10287K/13380K, paused 118ms, total 118ms
03-28 11:57:52.699: D/AndroidRuntime(836): Shutting down VM
03-28 11:57:52.709: W/dalvikvm(836): threadid=1: thread exiting with uncaught exception (group=0x41465700)
03-28 11:57:52.739: E/AndroidRuntime(836): FATAL EXCEPTION: main
03-28 11:57:52.739: E/AndroidRuntime(836): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.irrlicht.example/android.app.NativeActivity}: java.lang.IllegalArgumentException: Unable to load native library: /data/app-lib/com.irrlicht.example-1/libHelloWorldMobile.so
03-28 11:57:52.739: E/AndroidRuntime(836):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2211)
03-28 11:57:52.739: E/AndroidRuntime(836):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261)
03-28 11:57:52.739: E/AndroidRuntime(836):  at android.app.ActivityThread.access$600(ActivityThread.java:141)
03-28 11:57:52.739: E/AndroidRuntime(836):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)
03-28 11:57:52.739: E/AndroidRuntime(836):  at android.os.Handler.dispatchMessage(Handler.java:99)
03-28 11:57:52.739: E/AndroidRuntime(836):  at android.os.Looper.loop(Looper.java:137)
03-28 11:57:52.739: E/AndroidRuntime(836):  at android.app.ActivityThread.main(ActivityThread.java:5103)
03-28 11:57:52.739: E/AndroidRuntime(836):  at java.lang.reflect.Method.invokeNative(Native Method)
03-28 11:57:52.739: E/AndroidRuntime(836):  at java.lang.reflect.Method.invoke(Method.java:525)
03-28 11:57:52.739: E/AndroidRuntime(836):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
03-28 11:57:52.739: E/AndroidRuntime(836):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
03-28 11:57:52.739: E/AndroidRuntime(836):  at dalvik.system.NativeStart.main(Native Method)
03-28 11:57:52.739: E/AndroidRuntime(836): Caused by: java.lang.IllegalArgumentException: Unable to load native library: /data/app-lib/com.irrlicht.example-1/libHelloWorldMobile.so
03-28 11:57:52.739: E/AndroidRuntime(836):  at android.app.NativeActivity.onCreate(NativeActivity.java:184)
03-28 11:57:52.739: E/AndroidRuntime(836):  at android.app.Activity.performCreate(Activity.java:5133)
03-28 11:57:52.739: E/AndroidRuntime(836):  at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
03-28 11:57:52.739: E/AndroidRuntime(836):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2175)
03-28 11:57:52.739: E/AndroidRuntime(836):  ... 11 more
03-28 11:57:52.779: W/ActivityManager(275):   Force finishing activity com.irrlicht.example/android.app.NativeActivity
卡尔提克·西瓦姆(Karthik Sivam)

我已经通过创建本机活动的子类并加载共享库来解决此问题,如下所示:

package com.irrlicht.example;

public class MyActivity extends android.app.NativeActivity {

    static {
       System.loadLibrary("HelloWorldMobile");
       System.loadLibrary("openal");
    }
 }

在AndroidManfest.xml中,我包含MyActivity而不是android.app.NativeActivity这里得到了这个解决方案但是有没有一种方法可以完全解决此问题而无需使用java类?

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章

来自分类Dev

Android java.lang.illegalargumentException无法找到本机库main

来自分类Dev

coco2d-x:java.lang.IllegalArgumentException:无法找到本机库

来自分类Dev

在Android 5.0中加载本机库时出现java.lang.UnsatisfiedLinkError

来自分类Dev

java.lang.UnsatisfiedLinkError:本机库XXX.so已加载到另一个类加载器中

来自分类Dev

java.lang.IllegalArgumentException:无法创建组件

来自分类Dev

无法加载lang :: java :: jdt :: Java

来自分类Dev

java.lang.UnsatisfiedLinkError:无法加载库

来自分类Dev

java.lang.UnsatisfiedLinkError:无法加载库

来自分类Dev

错误:java.lang.IllegalArgumentException

来自分类Dev

面对 java.lang.IllegalArgumentException

来自分类Dev

运行Clojure JAR时Java无法找到本机库

来自分类Dev

运行Clojure JAR时Java无法找到本机库

来自分类Dev

java.lang.IllegalArgumentException:无法将java.lang.Short字段设置为java.lang.Short

来自分类Dev

java.lang.IllegalArgumentException:无法将java.lang.Short字段设置为java.lang.Short

来自分类Dev

java.lang.IllegalArgumentException:无法识别的类型:[null]

来自分类Dev

java.lang.illegalargumentexception:无法设置空的TableModel

来自分类Dev

java.lang.IllegalArgumentException:无法序列化 myclass

来自分类Dev

java.lang.IllegalArgumentException:at android.view.Surface.unlockCanvasAndPost(本机方法)

来自分类Dev

java.lang.IllegalArgumentException:at android.view.Surface.unlockCanvasAndPost(本机方法)

来自分类Dev

无法运行FIJI / imagej,java / lang / NoClassDefFoundError:java / lang / Object

来自分类Dev

本机库,Java OpenAL要求

来自分类Dev

Java.lang.Class.newInstance()抛出IllegalArgumentException

来自分类Dev

java.lang.IllegalArgumentException:未知实体

来自分类Dev

jnetpcap获取java.lang.IllegalArgumentException

来自分类Dev

JPA:java.lang.IllegalArgumentException:不是实体

来自分类Dev

java.lang.IllegalArgumentException:发布管理

来自分类Dev

奇怪的java.lang.IllegalArgumentException异常

来自分类Dev

java.lang.IllegalArgumentException:provider =网络

来自分类Dev

java.lang.illegalArgumentException意外显示

Related 相关文章

  1. 1

    Android java.lang.illegalargumentException无法找到本机库main

  2. 2

    coco2d-x:java.lang.IllegalArgumentException:无法找到本机库

  3. 3

    在Android 5.0中加载本机库时出现java.lang.UnsatisfiedLinkError

  4. 4

    java.lang.UnsatisfiedLinkError:本机库XXX.so已加载到另一个类加载器中

  5. 5

    java.lang.IllegalArgumentException:无法创建组件

  6. 6

    无法加载lang :: java :: jdt :: Java

  7. 7

    java.lang.UnsatisfiedLinkError:无法加载库

  8. 8

    java.lang.UnsatisfiedLinkError:无法加载库

  9. 9

    错误:java.lang.IllegalArgumentException

  10. 10

    面对 java.lang.IllegalArgumentException

  11. 11

    运行Clojure JAR时Java无法找到本机库

  12. 12

    运行Clojure JAR时Java无法找到本机库

  13. 13

    java.lang.IllegalArgumentException:无法将java.lang.Short字段设置为java.lang.Short

  14. 14

    java.lang.IllegalArgumentException:无法将java.lang.Short字段设置为java.lang.Short

  15. 15

    java.lang.IllegalArgumentException:无法识别的类型:[null]

  16. 16

    java.lang.illegalargumentexception:无法设置空的TableModel

  17. 17

    java.lang.IllegalArgumentException:无法序列化 myclass

  18. 18

    java.lang.IllegalArgumentException:at android.view.Surface.unlockCanvasAndPost(本机方法)

  19. 19

    java.lang.IllegalArgumentException:at android.view.Surface.unlockCanvasAndPost(本机方法)

  20. 20

    无法运行FIJI / imagej,java / lang / NoClassDefFoundError:java / lang / Object

  21. 21

    本机库,Java OpenAL要求

  22. 22

    Java.lang.Class.newInstance()抛出IllegalArgumentException

  23. 23

    java.lang.IllegalArgumentException:未知实体

  24. 24

    jnetpcap获取java.lang.IllegalArgumentException

  25. 25

    JPA:java.lang.IllegalArgumentException:不是实体

  26. 26

    java.lang.IllegalArgumentException:发布管理

  27. 27

    奇怪的java.lang.IllegalArgumentException异常

  28. 28

    java.lang.IllegalArgumentException:provider =网络

  29. 29

    java.lang.illegalArgumentException意外显示

热门标签

归档