Сбой приложения Android при запуске в начале приложения

Приложение вылетало при запуске в начале приложения. Приведенные ниже проблемы сбоя, которые я упомянул здесь, только что были показаны, когда я вручную помещал app-debug.apkfile в мобильное устройство после завершения установки. Но в случае запуска приложения через студию Android оно будет работать нормально. Ни одна точка сбоя не укажет.

Еще одна вещь: я добавил все Activities в свой манифест приложения.

Исключение Android RuneTime:

FATAL EXCEPTION: main

                                                                       Process: com.interfinet.jobtree, PID: 23960
                                                                            java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.interfinet.jobtree/com.interfinet.jobtree.SplashScreen}: java.lang.ClassNotFoundException: Didn't find class "com.interfinet.jobtree.SplashScreen" on path: DexPathList[[zip file "/data/app/com.interfinet.jobtree-1/base.apk"],nativeLibraryDirectories=[/vendor/lib, /system/lib]]
                                                                                at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2250)
                                                                                at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2413)
                                                                                at android.app.ActivityThread.access$800(ActivityThread.java:155)
                                                                                at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1317)
                                                                                at android.os.Handler.dispatchMessage(Handler.java:102)
                                                                                at android.os.Looper.loop(Looper.java:135)
                                                                                at android.app.ActivityThread.main(ActivityThread.java:5343)
                                                                                at java.lang.reflect.Method.invoke(Native Method)
                                                                                at java.lang.reflect.Method.invoke(Method.java:372)
                                                                                at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:905)
                                                                                at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:700)
                                                                             Caused by: java.lang.ClassNotFoundException: Didn't find class "com.interfinet.jobtree.SplashScreen" on path: DexPathList[[zip file "/data/app/com.interfinet.jobtree-1/base.apk"],nativeLibraryDirectories=[/vendor/lib, /system/lib]]
                                                                                at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
                                                                                at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
                                                                                at java.lang.ClassLoader.loadClass(ClassLoader.java:469)
                                                                                at android.app.Instrumentation.newActivity(Instrumentation.java:1089)
                                                                                at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2240)
                                                                                at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2413) 
                                                                                at android.app.ActivityThread.access$800(ActivityThread.java:155) 
                                                                                at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1317) 
                                                                                at android.os.Handler.dispatchMessage(Handler.java:102) 
                                                                                at android.os.Looper.loop(Looper.java:135) 
                                                                                at android.app.ActivityThread.main(ActivityThread.java:5343) 
                                                                                at java.lang.reflect.Method.invoke(Native Method) 
                                                                                at java.lang.reflect.Method.invoke(Method.java:372) 
                                                                                at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:905) 
                                                                                at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:700) 
                                                                                Suppressed: java.lang.ClassNotFoundException: com.interfinet.jobtree.SplashScreen
                                                                                at java.lang.Class.classForName(Native Method)
                                                                                at java.lang.BootClassLoader.findClass(ClassLoader.java:781)
                                                                                at java.lang.BootClassLoader.loadClass(ClassLoader.java:841)
                                                                                at java.lang.ClassLoader.loadClass(ClassLoader.java:504)
                                                                                        ... 13 more
                                                                             Caused by: java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack available
    05-11 17:53:51.758 23960-23960/com.interfinet.jobtree I/Process: Sending signal. PID: 23960 SIG: 9

файл app.gradle:

apply plugin: 'com.android.application'

android {
    compileSdkVersion 25
    buildToolsVersion '25.0.0'

    defaultConfig {
        applicationId "com.interfinet.jobtree"
        minSdkVersion 15
        targetSdkVersion 23
        versionCode 1
        versionName "1.0"
        multiDexEnabled true

    }
    buildTypes {
        release {
            minifyEnabled false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.pro'
        }
    }

    aaptOptions {
        additionalParameters "--no-version-vectors"
    }
}

dependencies {
    compile fileTree(dir: 'libs', include: ['*.jar'])
    compile project(':linkedin-sdk')
    testCompile 'junit:junit:4.12'
    compile 'com.android.support:appcompat-v7:25.3.1'
    compile 'com.android.support:design:25.3.1'
    compile 'com.android.support:recyclerview-v7:25.3.1'
    compile 'com.android.support:cardview-v7:25.3.1'
    compile 'de.hdodenhof:circleimageview:2.1.0'
    compile 'com.mikhaellopez:circularimageview:3.0.2'
    compile 'com.google.android.gms:play-services-maps:8.4.0'
    compile 'com.google.android.gms:play-services-location:8.4.0'
    compile 'org.jbundle.util.osgi.wrapped:org.jbundle.util.osgi.wrapped.org.apache.http.client:4.1.2'
    compile 'com.jaredrummler:material-spinner:1.1.0'
    compile 'com.squareup.picasso:picasso:2.5.2'
    compile 'com.android.support:multidex:1.0.0'
    compile 'com.facebook.android:facebook-android-sdk:4.0.0'
    compile 'com.wdullaer:materialdatetimepicker:3.1.3'
    compile 'at.blogc:expandabletextview:1.0.3'
}

Файл манифеста.xml:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
    package="com.interfinet.jobtree">

    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission android:name="android.permission.ACCESS_COARSE_LOCATION" />
    <uses-permission android:name="android.permission.ACCESS_FINE_LOCATION" />
    <uses-permission android:name="android.permission.READ_EXTERNAL_STORAGE" />
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

    <application
        android:allowBackup="true"
        android:icon="@mipmap/app_luncher_logo11"
        android:label="@string/app_name"
        android:supportsRtl="true"
        android:theme="@style/AppTheme.NoActionBar">
        <activity
            android:name=".SplashScreen"
            android:label="@string/app_name"
            android:theme="@style/AppTheme.NoActionBar">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity
            android:name=".OnboardActivity"
            android:screenOrientation="portrait"
            android:theme="@style/AppTheme.NoActionBar" />
        <activity
            android:name=".CredentialActivity"
            android:screenOrientation="portrait"
            android:theme="@style/AppTheme.Login"
            android:windowSoftInputMode="stateHidden|adjustResize" />
    </application>

</manifest>

comment
Это может быть проблема/функция в новом обновлении Android Studio. Ознакомиться с этим решением.   -  person Tony    schedule 14.06.2017


Ответы (6)


Перейдите в местоположение своего проекта, найдите файл .iml, затем удалите этот файл, перезапустите студию Android и создайте файл .apk. он будет работать нормально.

person Safa    schedule 11.05.2017
comment
Это файл .imi или .iml? Можете вкратце объяснить? - person pb123; 11.05.2017
comment
это .iml файл, может содержать неправильные данные. Как только вы удалите его и снова откроете свой проект, файл будет создан заново с правильными данными IML is a module file created by IntelliJ IDEA, an IDE used to develop Java applications. It stores information about a development module, which may be a Java, Plugin, Android, or Maven component; saves the module paths, dependencies, and other settings. - person Safa; 11.05.2017
comment
Удален myprojectname.iml из моего текущего проекта. Получение тех же проблем после того, как вы сделали то же самое, что вы упомянули здесь. - person pb123; 11.05.2017

удалите multiDexEnabled true из файла gradle и попробуйте

person EKN    schedule 11.05.2017
comment
та же точка сбоя, возникшая после удаления «multidexEnabled = true» из файла app.gradle - person pb123; 11.05.2017

Насколько мне известно, вы должны изменить имя своего пакета, а также действия в манифесте.

person Community    schedule 11.05.2017

В своем AndroidManifest.xml попробуйте использовать android:name="com.interfinet.jobtree.SplashScreen" вместо android:name=".SplashScreen".

AndroidManifest.xml

    ...........
    ................ 

    <activity
        android:name="com.interfinet.jobtree.SplashScreen"
        android:label="@string/app_name"
        android:theme="@style/AppTheme.NoActionBar">
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>

    ...........
    ................ 
person Ferdous Ahamed    schedule 11.05.2017
comment
Уже сделал это ... но ничего не произойдет ... получаю те же проблемы - person pb123; 11.05.2017
comment
очистите и перестройте свой проект снова - person Ferdous Ahamed; 11.05.2017

После некоторых исследований с той же проблемой.

Если вы только что обновили свою студию Android.

У вас не будет этой опции для отключения -> Мгновенный запуск. (нет в меню)

Похоже, что с новой студией Android и обновлением Gradle, чтобы установить apk, вам нужно правильно его собрать.

вариант 1: с помощью gradle из командной строки

./gradlew:имя_приложения:очистить ./gradlew:имя_приложения:сборка

Вариант 2: из студии Android

Android Studio -> сборка -> сборка APK (или создание вздохнувшего APK)

Сгенерированный apk можно установить на устройство.

Примечание: если вы запустите новое приложение с этой версией студии Android, вы увидите, что при запуске из студии больше не создается apk.

person beee    schedule 12.06.2017

Попробуйте удалить эту строку из файла gradle:

мультидексенаблед правда

person Jorge Vieira    schedule 20.12.2017