【发布时间】:2017-04-10 19:58:28
【问题描述】:
我花了好几个小时来解决这个问题,但在几十个类似问题的回复中找不到解决方案。
所以这是我的问题。我正在创建一个简单的 multidex Android 应用程序,我需要在应用程序启动时执行一些操作。因此,我扩展了 MultiDexApplication 类,在 AndroidManifest.xml 文件中添加了应用程序元素的类路径,但每次运行时都会崩溃,但出现以下异常:
java.lang.RuntimeException: Unable to instantiate application rmpt.app.MyApplication: java.lang.ClassNotFoundException: Didn't find class "rmpt.app.MyApplication" on path: DexPathList[[zip file "/data/app/rmpt.app-1.apk"],nativeLibraryDirectories=[/data/app-lib/rmpt.app-1, /vendor/lib, /system/lib, /system/lib/arm]]
at android.app.LoadedApk.makeApplication(LoadedApk.java:509)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4472)
at android.app.ActivityThread.access$1300(ActivityThread.java:144)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1355)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:150)
at android.app.ActivityThread.main(ActivityThread.java:5162)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:525)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:744)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.ClassNotFoundException: Didn't find class "rmpt.app.MyApplication" on path: DexPathList[[zip file "/data/app/rmpt.app-1.apk"],nativeLibraryDirectories=[/data/app-lib/rmpt.app-1, /vendor/lib, /system/lib, /system/lib/arm]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:53)
at java.lang.ClassLoader.loadClass(ClassLoader.java:501)
at java.lang.ClassLoader.loadClass(ClassLoader.java:461)
at android.app.Instrumentation.newApplication(Instrumentation.java:975)
at android.app.LoadedApk.makeApplication(LoadedApk.java:504)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4472)
at android.app.ActivityThread.access$1300(ActivityThread.java:144)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1355)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:150)
at android.app.ActivityThread.main(ActivityThread.java:5162)
at java.lang.reflect.Method.invokeNative(Native Method)
如果我从 AndroidManifest.xml 文件中删除 android:name 属性(因此它使用默认的 android Application 类)一切正常,但我需要在我的 onCreate 方法中执行一些操作应用。
我把我的文件留在这里,这样你就可以看到它们,并且可能会发现一些问题(已经尝试为我解决这个问题 2 天)
AndroidManifest.xml
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="rmpt.app">
<application
android:allowBackup="true"
android:icon="@mipmap/ic_launcher"
android:label="@string/app_name"
android:supportsRtl="true"
android:theme="@style/AppTheme"
android:name=".MyApplication">
<activity android:name=".view.LoginActivity">
<intent-filter>
<action android:name="android.intent.action.MAIN"/>
<category android:name="android.intent.category.LAUNCHER"/>
</intent-filter>
</activity>
</application>
</manifest>
MyApplication.java
package rmpt.app;
import android.support.multidex.MultiDexApplication;
public class MyApplication extends MultiDexApplication {
@Override
public void onCreate() {
super.onCreate();
// do my stuff
}
}
build.gradle
apply plugin: 'com.android.application'
android {
compileSdkVersion 23
buildToolsVersion "25.0.2"
defaultConfig {
applicationId "rmpt.app"
minSdkVersion 18
targetSdkVersion 23
versionCode 1
versionName "1.0"
testInstrumentationRunner "android.support.test.runner.AndroidJUnitRunner"
multiDexEnabled true
jackOptions {
enabled true
}
}
compileOptions {
sourceCompatibility JavaVersion.VERSION_1_8
targetCompatibility JavaVersion.VERSION_1_8
}
buildTypes {
release {
minifyEnabled false
proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
}
}
dexOptions {
javaMaxHeapSize "2g"
}
packagingOptions{
exclude 'META-INF/LICENSE.txt'
exclude 'META-INF/LICENSE'
}
}
dependencies {
compile fileTree(dir: 'libs', include: ['*.jar'])
testCompile 'junit:junit:4.12'
compile 'com.android.support:appcompat-v7:23.4.0'
compile 'com.android.support:multidex:1.0.1'
compile 'com.google.android.gms:play-services:9.4.0'
compile 'com.android.support:design:23.4.0'
}
我正在使用 MacOS 10.11.6
【问题讨论】:
-
不,我把这个放在哪里?
-
@rmpt 你解决了这个问题吗?如果没有:我建议(作为第一步)验证您的
MyApplication类是否包含在 classes.dex 中。您可以使用 ApkAnalyzer 从 Android Studio 直接执行此操作。 -
@Alex 我使用的是带有 Android 支持的 IntelliJ,而不是 Android Studio。有什么方法可以在其中使用 ApkAnalyzer 吗?我真的不明白,我在另一个项目上有类似的设置并且效果很好,在这个我有这个问题。
-
您可以使用 ClassyShark 代替 ApkAnalyzer。
-
如果您想针对 21 之前的 API 级别,您必须使用旧的 multidex 库。否则,设置 21 为 minSdkVersion 不使用(因为从这个版本开始平台已经内置支持)。
标签: android android-manifest classnotfoundexception android-multidex