【问题标题】:Android java.lang.IllegalArgumentException: Unable to find native library: mainAndroid java.lang.IllegalArgumentException:找不到本机库:main
【发布时间】:2015-06-05 13:15:35
【问题描述】:

今天找到了一些项目,演示了android ndk编程。这里是this projects

我正在尝试启动项目 DroidBlaster。我已经编译了所有本机库,没有错误。结果如下:

我只是做了一些小改动:

1)。在AndroidManifest.xml选项android:hasCode="true"中添加到application标签

2)。我从原生活动扩展并在static 活动块中加载所有库。

我这样做是因为,如果没有这些更改,android 无法找到在 AndroidManifest.xml 中声明的库 libdroidblaster.so(这是作者的代码)

<activity
            android:name="android.app.NativeActivity"
            android:label="@string/app_name" >
            <meta-data
                android:name="android.app.lib_name"
                android:value="droidblaster" />

            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>

现在我的AndroidManifest.xml 看起来像:

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.demo.droidblaster"
    android:versionCode="1"
    android:versionName="1.0" >

    <uses-sdk
        android:minSdkVersion="10"
        android:targetSdkVersion="22" />

    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme"
        android:hasCode="true">

        <activity android:name=".MainActivity"
                  android:label="@string/app_name"
                  android:configChanges="orientation|keyboardHidden">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>

        <activity
            android:name="android.app.NativeActivity"
            android:label="@string/app_name" >
            <meta-data
                android:name="android.app.lib_name"
                android:value="droidblaster" />
        </activity>
    </application>

    <uses-permission android:name="android.permission.RECORD_AUDIO" />

</manifest>

还有我的新活动

public class MainActivity extends NativeActivity {
    static {
        System.loadLibrary("irrlicht");
        System.loadLibrary("droidblaster");
    }

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
    }
}

当我尝试启动应用程序时,我收到此错误:

06-05 12:56:26.523 11528-11528/com.demo.droidblaster E/AndroidRuntime: FATAL EXCEPTION: main 进程:com.demo.droidblaster,PID:11528 java.lang.RuntimeException:无法启动活动 ComponentInfo{com.demo.droidblaster/com.demo.droidblaster.MainActivity}: java.lang.IllegalArgumentException:找不到本机库: 主要的 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2658) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2723) 在 android.app.ActivityThread.access$900(ActivityThread.java:172) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1422) 在 android.os.Handler.dispatchMessage(Handler.java:102) 在 android.os.Looper.loop(Looper.java:145) 在 android.app.ActivityThread.main(ActivityThread.java:5832) 在 java.lang.reflect.Method.invoke(本机方法) 在 java.lang.reflect.Method.invoke(Method.java:372) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1399) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1194) 引起:java.lang.IllegalArgumentException:无法找到本机库:main 在 android.app.NativeActivity.onCreate(NativeActivity.java:170) 在 com.demo.droidblaster.MainActivity.onCreate(MainActivity.java:17) 在 android.app.Activity.performCreate(Activity.java:6221) 在 android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1119) 在 android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2611) 在 android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2723) 在 android.app.ActivityThread.access$900(ActivityThread.java:172) 在 android.app.ActivityThread$H.handleMessage(ActivityThread.java:1422) 在 android.os.Handler.dispatchMessage(Handler.java:102) 在 android.os.Looper.loop(Looper.java:145) 在 android.app.ActivityThread.main(ActivityThread.java:5832) 在 java.lang.reflect.Method.invoke(本机方法) 在 java.lang.reflect.Method.invoke(Method.java:372) 在 com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:1399) 在 com.android.internal.os.ZygoteInit.main(ZygoteInit.java:1194)

所以,原因是:

java.lang.IllegalArgumentException: Unable to find native library: main

我找不到解决此问题的方法。

有人知道怎么解决吗?

【问题讨论】:

    标签: java android android-ndk


    【解决方案1】:

    .so 文件不会自动包含在 Android Studio 中。按照此处给出的答案将它们包括在内:https://stackoverflow.com/a/17131418/1395437

    【讨论】:

    • 感谢您的提问,但这对我没有帮助,而且我将库添加到项目中也没问题。应用程序无法加载库“主”。我需要修复加载“主”库,而不是“droidblaster”库。我会投票赞成你的问题
    【解决方案2】:

    您可以尝试使用 ndk-support 集成(实验性)安装新的 gradle。 http://ph0b.com/new-android-studio-ndk-support/#more-236 会有 android.ndk 框(在您的 gradle.build 中),您应该在其中添加 native_android_glue :

    android.ndk{

        moduleName = "droidblaster"
        CFlags.add("-I${file("src/main/jni/android_native_app_glue")}".toString())
        ldLibs.addAll(["log", "android", "EGL", "GLESv1_CM"])
    
    }
    

    【讨论】:

    • 它与我的问题有什么关系?
    【解决方案3】:
     externalNativeBuild {
                cmake {
                    arguments "-DANDROID_STL=c++_shared" //add this in the build.gradle
    
                }
            }
    

    【讨论】:

      【解决方案4】:

      我认为您必须删除您的第二个活动并将此标签 &lt;meta-data android:name="android.app.lib_name" android:value="droidblaster" /&gt; 添加到您的第一个活动中

      【讨论】:

        【解决方案5】:

        将 NativeActivity 更改为 AppCompatActivity。

        【讨论】:

          猜你喜欢
          • 2016-10-12
          • 2020-01-23
          • 1970-01-01
          • 2014-05-06
          • 1970-01-01
          • 2015-10-17
          • 1970-01-01
          • 1970-01-01
          • 1970-01-01
          相关资源
          最近更新 更多