web-dev-qa-db-fra.com

Échec du lancement de l'activité en raison de ClassNotFoundException

J'essaie de lancer une nouvelle activité en utilisant le code:

Intent i = new Intent(this, TempLobbyActivity.class);
startActivity(i);
finish();

Lorsque je lance ce code, les exceptions suivantes sont générées lors de l'exécution du constructeur Intent.

FATAL EXCEPTION: main
Process: com.edr.iveflownthat, PID: 1457
Java.lang.NoClassDefFoundError: Failed resolution of: Lcom/edr/iveflownthat/TempLobbyActivity;
    at com.edr.iveflownthat.pages.MainActivity.tryAutoLogin(MainActivity.Java:46)
    at com.edr.iveflownthat.pages.MainActivity.onCreate(MainActivity.Java:22)
    at Android.app.Activity.performCreate(Activity.Java:5933)
    at Android.app.Instrumentation.callActivityOnCreate(Instrumentation.Java:1105)
    at Android.app.ActivityThread.performLaunchActivity(ActivityThread.Java:2251)
    at Android.app.ActivityThread.handleLaunchActivity(ActivityThread.Java:2360)
    at Android.app.ActivityThread.access$800(ActivityThread.Java:144)
    at Android.app.ActivityThread$H.handleMessage(ActivityThread.Java:1278)
    at Android.os.Handler.dispatchMessage(Handler.Java:102)
    at Android.os.Looper.loop(Looper.Java:135)
    at Android.app.ActivityThread.main(ActivityThread.Java:5221)
    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:899)
    at com.Android.internal.os.ZygoteInit.main(ZygoteInit.Java:694)
Caused by: Java.lang.ClassNotFoundException: Didn't find class     "com.edr.iveflownthat.TempLobbyActivity" on path: DexPathList[[Zip file "/data/app/com.edr.iveflownthat-1/base.apk"],nativeLibraryDirectories=[/vendor/lib, /system/lib]]
FATAL EXCEPTION: main
Process: com.edr.iveflownthat, PID: 1457
Java.lang.NoClassDefFoundError: Failed resolution of: Lcom/edr/iveflownthat/TempLobbyActivity;
    at com.edr.iveflownthat.pages.MainActivity.tryAutoLogin(MainActivity.Java:46)
    at com.edr.iveflownthat.pages.MainActivity.onCreate(MainActivity.Java:22)
    at Android.app.Activity.performCreate(Activity.Java:5933)
    at Android.app.Instrumentation.callActivityOnCreate(Instrumentation.Java:1105)
    at Android.app.ActivityThread.performLaunchActivity(ActivityThread.Java:2251)
    at Android.app.ActivityThread.handleLaunchActivity(ActivityThread.Java:2360)
    at Android.app.ActivityThread.access$800(ActivityThread.Java:144)
    at Android.app.ActivityThread$H.handleMessage(ActivityThread.Java:1278)
    at Android.os.Handler.dispatchMessage(Handler.Java:102)
    at Android.os.Looper.loop(Looper.Java:135)
    at Android.app.ActivityThread.main(ActivityThread.Java:5221)
    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:899)
    at com.Android.internal.os.ZygoteInit.main(ZygoteInit.Java:694)
Caused by: Java.lang.ClassNotFoundException: Didn't find class "com.edr.iveflownthat.TempLobbyActivity" on path: DexPathList[[Zip file "/data/app/com.edr.iveflownthat-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)
    ... 15 more
Suppressed: Java.lang.NoClassDefFoundError: com.edr.iveflownthat.TempLobbyActivity
    at dalvik.system.DexFile.defineClassNative(Native Method)
    at dalvik.system.DexFile.defineClass(DexFile.Java:222)
    at dalvik.system.DexFile.loadClassBinaryName(DexFile.Java:215)
    at dalvik.system.DexPathList.findClass(DexPathList.Java:321)
    at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.Java:54)
    ... 17 more
Suppressed: Java.lang.ClassNotFoundException: com.edr.iveflownthat.TempLobbyActivity
    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)
    ... 16 more
Caused by: Java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack available  at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.Java:56)
    at Java.lang.ClassLoader.loadClass(ClassLoader.Java:511)
    at Java.lang.ClassLoader.loadClass(ClassLoader.Java:469)
    ... 15 more
Suppressed: Java.lang.NoClassDefFoundError: com.edr.iveflownthat.TempLobbyActivity
    at dalvik.system.DexFile.defineClassNative(Native Method)
    at dalvik.system.DexFile.defineClass(DexFile.Java:222)
    at dalvik.system.DexFile.loadClassBinaryName(DexFile.Java:215)
    at dalvik.system.DexPathList.findClass(DexPathList.Java:321)
    at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.Java:54)
    ... 17 more
Suppressed: Java.lang.ClassNotFoundException: com.edr.iveflownthat.TempLobbyActivity
    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)
    ... 16 more
Caused by: Java.lang.NoClassDefFoundError: Class not found using the boot class loader; no stack available

Je me suis assuré que la classe TempLobbyActivity existe et constitue une activité appropriée. Je ne reçois pas d'autres erreurs.

Voici le début de TempLobbyActivity:

package com.edr.iveflownthat;

import Android.app.Activity;
import Android.os.Bundle;
import Android.support.v4.app.Fragment;
import Android.support.v4.app.FragmentActivity;
import Android.support.v4.app.FragmentManager;
import Android.support.v4.widget.DrawerLayout;
import Android.support.v7.app.ActionBarDrawerToggle;
import Android.view.View;
import Android.widget.AdapterView;
import Android.widget.AdapterView.OnItemClickListener;
import Android.widget.ArrayAdapter;
import Android.widget.ListView;

import com.edr.iveflownthat.pages.fragments.LobbyLeaderboardFragment;
import com.edr.iveflownthat.pages.fragments.LobbyMessagerFragment;
import com.edr.iveflownthat.pages.fragments.LobbyMyPlanesFragment;

public class TempLobbyActivity extends FragmentActivity {

Et voici mon fichier manifeste:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:Android="http://schemas.Android.com/apk/res/Android"
    package="com.edr.iveflownthat"
    Android:versionCode="1"
    Android:versionName="1.0" >

    <uses-sdk
        Android:minSdkVersion="14"
        Android:targetSdkVersion="19" />

    <uses-permission Android:name="Android.permission.INTERNET" />
    <uses-permission Android:name="Android.permission.ACCESS_NETWORK_STATE" />
    <uses-permission Android:name="Android.permission.WRITE_EXTERNAL_STORAGE" />
    <uses-permission Android:name="Android.permission.GET_ACCOUNTS" />
    <uses-permission Android:name="Android.permission.USE_CREDENTIALS" />
    <uses-permission Android:name="Android.permission.ACCESS_COARSE_LOCATION" />

    <application
        Android:allowBackup="true"
        Android:icon="@drawable/app_logo"
        Android:label="@string/app_name"
        Android:theme="@style/AppTheme" >
        <meta-data
            Android:name="com.google.Android.gms.version"
            Android:value="@integer/google_play_services_version" />

        <activity
            Android:name=".pages.MainActivity"
            Android:label="@string/app_name" >
            <intent-filter>
                <action Android:name="Android.intent.action.MAIN" />

                <category Android:name="Android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity
            Android:name=".StartActivity"
            Android:label="@string/title_activity_start" >
        </activity>
        <activity
            Android:name=".pages.AccountLoginActivity"
        Android:label="@string/title_activity_login" >
        </activity>
        <activity
            Android:name=".pages.MyPlanesActivity"
            Android:label="@string/title_activity_my_planes" >
        </activity>
        <activity
            Android:name="com.edr.icom.edr.iveflownthat.activities.AccountNewActivity"
            Android:label="@string/title_activity_new_account" >
        </activity>
        <activity
            Android:name=".pages.SearchPlanesActivity"
            Android:label="@string/title_activity_search"
            Android:parentActivityName=".pages.LobbyActivity" >
            <meta-data
                Android:name="Android.support.PARENT_ACTIVITY"
                Android:value="com.edr.iveflownthat.pages.LobbyActivity" />
        </activity>
        <activity
            Android:name=".pages.LeaderBoardActivity"
            Android:label="@string/title_activity_leader_board" >
        </activity>
        <activity
            Android:name=".pages.PlaneBioActivity"
            Android:label="@string/title_activity_plane_info" >
        </activity>
        <activity
            Android:name=".pages.AccountLoginFacebookActivity"
            Android:label="@string/title_activity_account_login_facebook" >
        </activity>
        <activity
            Android:name=".pages.AccountLoginGoogleActivity"
            Android:label="@string/title_activity_account_login_google" >
        </activity>
        <activity
            Android:name=".pages.AccountLoginTwitterActivity"
            Android:label="@string/title_activity_account_login_Twitter" >
        </activity>
        <activity
            Android:name=".pages.SettingsActivity"
            Android:label="@string/title_activity_settings" >
        </activity>
        <activity
            Android:name=".pages.MainTabActivity"
            Android:label="@string/title_activity_main_tab" >
        </activity>
        <activity
            Android:name=".pages.LobbyActivity"
            Android:label="@string/title_activity_lobby" >
        </activity>
        <activity
            Android:name=".pages.MessageStreamActivity"
            Android:label="@string/title_activity_message_stream"
            Android:parentActivityName=".pages.LobbyActivity" >
            <meta-data
                Android:name="Android.support.PARENT_ACTIVITY"
                Android:value="com.edr.iveflownthat.pages.LobbyActivity" />
        </activity>
        <activity
            Android:name=".pages.LeaderboardActivity"
            Android:label="@string/title_activity_leaderboard"
            Android:parentActivityName=".pages.LobbyActivity" >
        <meta-data
                Android:name="Android.support.PARENT_ACTIVITY"
                Android:value="com.edr.iveflownthat.pages.LobbyActivity" />
        </activity>

        <service
            Android:name=".services.MainService"
            Android:exported="false" />

        <activity
            Android:name=".pages.NewMessageActivity"
            Android:label="@string/title_activity_new_message" >
        </activity>
        <activity
            Android:name=".pages.PlaneActivity"
            Android:label="@string/title_activity_plane" >
        </activity>
        <!--
        <meta-data
            Android:name="com.facebook.sdk.ApplicationId"
            Android:value="@string/app_id" />

        <activity
            Android:name="com.facebook.LoginActivity"
            Android:label="@string/app_name" >
        </activity>
        -->
        <activity
            Android:name=".TempLobbyActivity"
            Android:label="@string/title_activity_temp_lobby" >
        </activity>
    </application>

</manifest>
14
Eric Siegal

J'obtenais la même erreur même si la classe était définie dans AndroidManifest.xml.

Cause : Parfois, cela se produit lorsque vous ajoutez plusieurs versions de la bibliothèque appcompat.

Solution : Supprimez toutes les versions précédentes de appcompat lib et ajoutez appcompat_v7.jar dans votre dossier/lib.

Nettoyez votre projet et construisez à nouveau. Vous pourriez ne pas avoir d'erreur à nouveau.

13
kinjal patel

Enregistrez votre TempLobbyActivity sur votre AndroidManifest.xml

<activity Android:name="TempLobbyActivity"></activity>

Donc, votre fichier manifeste devrait être comme ça

<activity Android:name=".MainActivity"
              Android:label="@string/app_name" >
        <intent-filter>
            <action Android:name="Android.intent.action.MAIN"/>
            <category Android:name="Android.intent.category.LAUNCHER"/>        
        </intent-filter>
    </activity>
<activity Android:name="TempLobbyActivity"></activity>
0
Reinaldo

J'ai constaté que j'avais une erreur dans la console que j'avais ignorée:

[ExoPlayerLib] Impossible de trouver ExoPlayerLib.apk.

En résolvant ceci avec SO answer , l'erreur secondaire de NoClassDefFoundError a également été résolue.

On dirait que tout problème lié à la construction et à l'inclusion de bibliothèques dans un projet peut être la cause de ce problème.

0
barkside

Il y a un bogue sur le niveau 10 de l'API (Android 2.3.3 - 2.3.7) depuis le 21 novembre (éventuellement dans la bibliothèque des services de lecture):

Voir ce rapport de bogue:https://code.google.com/p/Android/issues/detail?id=81083

0
Majkel

Pour ceux qui peuvent encore faire face à ce problème:

Ajoutez les dépendances appropriées à votre build.gradle. Une telle erreur survient lorsque les dépendances ne sont pas correctement ajoutées et que Gradle ne compile pas les bibliothèques ajoutées au projet. Par conséquent, vous n’accédez pas à ces classes de bibliothèques au moment de l’exécution. 

0
Masoud Dadashi