java.lang.ClassNotFoundException:未找到 class …路径:DexPathList

java.lang.ClassNotFoundException: Didn't find class … on path: DexPathList

我正在尝试为 android 构建 SFML 应用程序,但出现了一些奇怪的错误。 首先,我的应用程序配置如下:

Android.mk

LOCAL_PATH := $(call my-dir)

include $(CLEAR_VARS)

LOCAL_MODULE    := sfml-example

LOCAL_SRC_FILES := main.cpp

LOCAL_SHARED_LIBRARIES := sfml-system
LOCAL_SHARED_LIBRARIES += sfml-window
LOCAL_SHARED_LIBRARIES += sfml-graphics
LOCAL_SHARED_LIBRARIES += sfml-audio
LOCAL_SHARED_LIBRARIES += sfml-network
LOCAL_SHARED_LIBRARIES += sfml-activity
LOCAL_SHARED_LIBRARIES += openal
LOCAL_WHOLE_STATIC_LIBRARIES := sfml-main

include $(BUILD_SHARED_LIBRARY)

$(call import-module,third_party/sfml)

Application.mk

NDK_TOOLCHAIN_VERSION := 4.9
APP_PLATFORM := android-19
APP_STL := c++_static
APP_ABI := all
APP_MODULES := sfml-activity sfml-example
APP_OPTIM := release
APP_CFLAG := -g -O3

它已编译并在 Android 5、6、7 上运行良好。但是当我尝试在 android 6.0 上启动应用程序时出现错误:

java.lang.RuntimeException: Unable to start activity ComponentInfo{org.sfml_test.android/android.app.NativeActivity}: java.lang.IllegalArgumentException: Unable to load native library: /data/app/org.sfmldev.android-1/lib/arm/libsfml-activity.so

我在 this 问题中发现了类似的问题。 所以我尝试编写 activity,它应该加载 SFML 库。 Activity代码:

package org.sfmldev.android;

import android.app.Activity;
import android.content.Intent;
import android.os.Bundle;


public class SFMLLoader  extends Activity {
    static {
        System.loadLibrary("sfml-activity");
        System.loadLibrary("sfml-example");
    }
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);

        Intent intent = new Intent(SFMLLoader.this, android.app.NativeActivity.class);
        SFMLLoader.this.startActivity(intent);
    }
}

我改变了我的 AndroidManifest.xml:

<?xml version="1.0" encoding="utf-8"?>

<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    package="org.sfmldev.android">

    <uses-feature android:glEsVersion="0x00010001" />

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


    <application android:label="@string/app_name"
                 android:icon="@drawable/sfml_logo"
                 android:hasCode="false"
                 android:allowBackup="false"
                 android:testOnly="false"
        tools:ignore="GoogleAppIndexingWarning">

        <activity android:name="org.sfmldev.android.SFMLLoader"
            android:label="@string/app_name"
            android:configChanges="keyboardHidden|orientation|screenSize">
            <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"
              android:icon="@drawable/sfml_logo"
              android:configChanges="keyboardHidden|orientation|screenSize">

        <meta-data android:name="android.app.lib_name" android:value="sfml-activity" />
        <meta-data android:name="sfml.app.lib_name" android:value="sfml-example" />

    </activity>
    </application>
</manifest>

现在我在任何设备上都有新错误:

java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{org.sfmldev.android/org.sfmldev.android.SFMLLoader}: java.lang.ClassNotFoundException: Didn't find class "org.sfmldev.android.SFMLLoader" on path: DexPathList[[directory "."],nativeLibraryDirectories=[/vendor/lib, /system/lib]]

我已经尝试创建相对路径,禁用实例 运行,清理项目,重启 android studio,重启 OS,删除 .idea 和 .gradle

你应该在运行时而不是在 activity 创建时加载你的库:

public class SFMLLoader extends Activity {
    static {
        System.loadLibrary("sfml-activity");
        System.loadLibrary("sfml-example");
    }

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

刚刚忘记从 AndroidManifest.xml

中删除 android:hasCode="false"