我有一个使用Ionic 3和Cordova-Android 6.4.0的应用程序。该应用程序在Android API级别〉19(Kitkat)上运行良好。但在Android 4.4上运行该应用程序会导致应用程序在启动时崩溃,以下情况除外:
03-21 14:07:40.513 2408-2408/com.xxx.app.xxx E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.xxx.app.xxx, PID: 2408
java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.xxx.app.xxx/com.xxx.app.xxx.MainActivity}: java.lang.ClassNotFoundException: Didn't find class "com.xxx.app.xxx.MainActivity" on path: DexPathList[[zip file "/data/app/com.xxx.app.xxx-2.apk"],nativeLibraryDirectories=[/data/app-lib/com.xxx.app.xxx-2, /system/lib]]
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2121)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
at android.app.ActivityThread.access$800(ActivityThread.java:135)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5017)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.ClassNotFoundException: Didn't find class "com.xxx.app.xxx.MainActivity" on path: DexPathList[[zip file "/data/app/com.xxx.app.xxx-2.apk"],nativeLibraryDirectories=[/data/app-lib/com.xxx.app.xxx-2, /system/lib]]
at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
at java.lang.ClassLoader.loadClass(ClassLoader.java:497)
at java.lang.ClassLoader.loadClass(ClassLoader.java:457)
at android.app.Instrumentation.newActivity(Instrumentation.java:1061)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2112)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245)
at android.app.ActivityThread.access$800(ActivityThread.java:135)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:136)
at android.app.ActivityThread.main(ActivityThread.java:5017)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:515)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
at dalvik.system.NativeStart.main(Native Method)
我读过有关multidex修复的文章,但我不能将其应用于我的Ionic应用程序,因为我不能更改生成的Java代码来添加MultiDex.install(this);
。
有人能解决这个问题吗?
1条答案
按热度按时间nzk0hqpo1#
此处描述了问题和解决方案。
java.lang.ClassNotFoundException
来自这样一个事实,即应用程序及其库超过65,536个方法,因此Java类分布在多个DEX文件中(Dalvik EXecutable),即classes.dex、classes2.dex等。启动应用所需的Java类可能最终位于应用APK内的classes2.dex中(与classes.dex相反),在低于5的Android版本中,Dalvik运行时将无法加载它。请访问Android网站:为multidex应用构建每个DEX文件时,构建工具会执行复杂的决策,以确定主DEX文件中需要哪些类,以便您的应用可以成功启动。如果主DEX文件中未提供启动期间所需的任何类,则您的应用会崩溃,并显示错误java.lang.NoClassDefFoundError。
解决方案是在文本文件中标识应用程序启动时引用的每个类,如我的帖子开头的链接所述。
但是,所需类的列表很长,很难建立。我得到了下面的类,但仍然有更多的启动类需要发现。我的解决方案是说“对不起,这个应用程序只适用于Android 5和更高版本”。