【发布时间】:2018-10-24 16:47:27
【问题描述】:
我正在使用Android Studio 3.1.2 & Gradle 3.1.2 & minSdkVersion 19 & compileSdkVersion 26 并在运行Nougat 的模拟器和运行Oreo 的智能手机上进行测试,一旦我启动应用程序就会出现此异常
E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.***.***.****, PID: 16366
java.lang.RuntimeException: Unable to instantiate application com.***.***.***.view.application.MyApplicationClass: java.lang.ClassNotFoundException: Didn't find class "com.***.***.***.view.application.MyApplicationClass" on path: DexPathList[[zip file "/data/app/com.***.***.***-2/base.apk"],nativeLibraryDirectories=[/data/app/com.***.***.***-2/lib/x86, /data/app/com.***.***.***-2/base.apk!/lib/x86, /system/lib, /vendor/lib]]
at android.app.LoadedApk.makeApplication(LoadedApk.java:802)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:5377)
at android.app.ActivityThread.-wrap2(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1545)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6119)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:886)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:776)
Caused by: java.lang.ClassNotFoundException: Didn't find class "com.***.***.***.view.application.MyApplicationClass" on path: DexPathList[[zip file "/data/app/com.***.***.***-2/base.apk"],nativeLibraryDirectories=[/data/app/com.***.***.***-2/lib/x86, /data/app/com.***.***.***-2/base.apk!/lib/x86, /system/lib, /vendor/lib]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
at java.lang.ClassLoader.loadClass(ClassLoader.java:380)
at java.lang.ClassLoader.loadClass(ClassLoader.java:312)
at android.app.Instrumentation.newApplication(Instrumentation.java:992)
at android.app.LoadedApk.makeApplication(LoadedApk.java:796)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:5377)
at android.app.ActivityThread.-wrap2(ActivityThread.java)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1545)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:154)
at android.app.ActivityThread.main(ActivityThread.java:6119)
at java.lang.reflect.Method.invoke(Native Method)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:886)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:776)
-
MyApplicationClass扩展MultiDexApplication - 我正在清单文件
android:name=".view.application.MyApplicationClass"中注册该类 - 我在
gradle.build和multiDexEnabled true中启用MultiDex - 我使用
compile 'com.android.support:multidex:1.0.2'是为了向后兼容 - 我正在使用SOASTA mPulse library 进行性能监控
当我使用apply plugin: 'com.soasta.mpulse.android'启用此库时会发生异常,否则应用程序可以正常工作。
我尝试了许多解决方案,但没有一个有效:
- https://developer.android.com/studio/build/multidex
- http://myhexaville.com/2017/03/10/android-multidex/
2 天来一直在尝试解决此问题,非常感谢任何帮助
【问题讨论】:
标签: android build android-gradle-plugin