Мое приложение flutter завершает работу в момент запуска со следующей ошибкой:

#android #flutter

#Android #флаттер

Вопрос:

После того, как приложение запускается и существует мгновенно, консоль выдает следующую ошибку:

Я искал много решений для нее и там, но ничего не мог понять.

Помощь действительно ценится. Кстати, это единственное, что мешает мне выпустить мое приложение и опубликовать его. Большое спасибо.

 √ Built buildappoutputsflutter-apkapp-debug.apk.
Installing buildappoutputsflutter-apkapp.apk...
E/AndroidRuntime(13552): FATAL EXCEPTION: main
E/AndroidRuntime(13552): Process: com.comet.manga, PID: 13552
E/AndroidRuntime(13552): java.lang.RuntimeException: Unable to instantiate application com.comet.manga.Application: java.lang.ClassNotFoundException: Didn't find class "com.comet.manga.Application" on path: DexPathList[[zip file "/data/app/com.comet.manga-3NMRdDTvHVRYO7itAb__EQ==/base.apk"],nativeLibraryDirectories=[/data/app/com.comet.manga-3NMRdDTvHVRYO7itAb__EQ==/lib/x86, /data/app/com.comet.manga-3NMRdDTvHVRYO7itAb__EQ==/base.apk!/lib/x86, /system/lib, /system/product/lib]]
E/AndroidRuntime(13552):    at android.app.LoadedApk.makeApplication(LoadedApk.java:1226)
E/AndroidRuntime(13552):    at android.app.ActivityThread.handleBindApplication(ActivityThread.java:6431)
E/AndroidRuntime(13552):    at android.app.ActivityThread.access$1300(ActivityThread.java:219)
E/AndroidRuntime(13552):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1859)
E/AndroidRuntime(13552):    at android.os.Handler.dispatchMessage(Handler.java:107)
E/AndroidRuntime(13552):    at android.os.Looper.loop(Looper.java:214)
E/AndroidRuntime(13552):    at android.app.ActivityThread.main(ActivityThread.java:7356)
E/AndroidRuntime(13552):    at java.lang.reflect.Method.invoke(Native Method)
E/AndroidRuntime(13552):    at com.android.internal.os.RuntimeInit$MethodAndArgsCaller.run(RuntimeInit.java:492)
E/AndroidRuntime(13552):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:930)
E/AndroidRuntime(13552): Caused by: java.lang.ClassNotFoundException: Didn't find class "com.comet.manga.Application" on path: DexPathList[[zip file "/data/app/com.comet.manga-3NMRdDTvHVRYO7itAb__EQ==/base.apk"],nativeLibraryDirectories=[/data/app/com.comet.manga-3NMRdDTvHVRYO7itAb__EQ==/lib/x86, /data/app/com.comet.manga-3NMRdDTvHVRYO7itAb__EQ==/base.apk!/lib/x86, /system/lib, /system/product/lib]]
E/AndroidRuntime(13552):    at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:196)
E/AndroidRuntime(13552):    at java.lang.ClassLoader.loadClass(ClassLoader.java:379)
E/AndroidRuntime(13552):    at java.lang.ClassLoader.loadClass(ClassLoader.java:312)
E/AndroidRuntime(13552):    at android.app.AppComponentFactory.instantiateApplication(AppComponentFactory.java:76)
E/AndroidRuntime(13552):    at androidx.core.app.CoreComponentFactory.instantiateApplication(CoreComponentFactory.java:52)
E/AndroidRuntime(13552):    at android.app.Instrumentation.newApplication(Instrumentation.java:1148)
E/AndroidRuntime(13552):    at android.app.LoadedApk.makeApplication(LoadedApk.java:1218)
E/AndroidRuntime(13552):    ... 9 more
  

Комментарии:

1. Если он не может найти ваш класс приложения, скорее всего, его там нет. Почему бы вам не попробовать разархивировать apk и изучить его?

Ответ №1:

Я думаю, что ваша ошибка вызвана тем Dex Error , что ее можно устранить, включив multiDex. Итак, в вашем android/app каталоге добавьте эти строки в build.gradle файл:

 android {
    defaultConfig {
        ...
        multiDexEnabled true
    }
}

dependencies {
  implementation 'com.android.support:multidex:1.0.3'
  ....
  

Комментарии:

1. У меня был включен multidex, я просто добавил реализацию. Спасибо

Ответ №2:

Если ваше приложение предназначено для 21 уровня api и выше, MultiDex включен по умолчанию