Что вызывает это ClassNotFoundException в Android?

1

Я не понимаю, что может быть за этим исключением. Это было анонимно сообщено одним пользователем моего приложения, я не могу воспроизвести его.

java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{cz.fhejl.pubtran/cz.fhejl.pubtran.CustomMainActivity}: java.lang.ClassNotFoundException: cz.fhejl.pubtran.CustomMainActivity in loader dalvik.system.PathClassLoader[/system/framework/com.google.android.maps.jar:/data/app/cz.fhejl.pubtran-2.apk]
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2585)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
at android.app.ActivityThread.access$2300(ActivityThread.java:125)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:123)
at android.app.ActivityThread.main(ActivityThread.java:4627)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:521)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.ClassNotFoundException: cz.fhejl.pubtran.CustomMainActivity in loader dalvik.system.PathClassLoader[/system/framework/com.google.android.maps.jar:/data/app/cz.fhejl.pubtran-2.apk]
at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:243)
at java.lang.ClassLoader.loadClass(ClassLoader.java:573)
at java.lang.ClassLoader.loadClass(ClassLoader.java:532)
at android.app.Instrumentation.newActivity(Instrumentation.java:1021)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2577)
... 11 more

Мой AndroidManifest.xml

<?xml version="1.0" encoding="utf-8"?>
<manifest
    xmlns:android="http://schemas.android.com/apk/res/android"
    package="cz.fhejl.pubtran"
    android:versionCode="38"
    android:versionName="3.6"
    android:installLocation="auto">

    <application
        android:icon="@drawable/icon"
        android:label="@string/appName"
        android:theme="@style/Theme.Pubtran">
        <activity
            android:name="cz.fhejl.pubtran.CustomMainActivity">
            <intent-filter>
                <action
                    android:name="android.intent.action.MAIN" />
                <category
                    android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
            <intent-filter>
                <action
                    android:name="cz.fhejl.pubtran.MAIN_ACTIVITY" />
                <category
                    android:name="android.intent.category.DEFAULT" />
            </intent-filter>
        </activity>
        <activity
            android:name="cz.fhejl.pubtran.CustomResultsActivity">
            <intent-filter>
                <action
                    android:name="cz.fhejl.pubtran.RESULTS_ACTIVITY" />
                <category
                    android:name="android.intent.category.DEFAULT" />
            </intent-filter>
        </activity>
        <activity
            android:name="cz.fhejl.pubtran.JourneyActivity" />
        <activity
            android:name="cz.fhejl.pubtran.PreferencesActivity"
            android:theme="@android:style/Theme.Light"
            android:label="@string/settings" />
        <activity
            android:name="cz.fhejl.pubtran.MapActivity" />
        <activity
            android:name="cz.fhejl.pubtran.LanguageActivity" />
        <activity
            android:name="cz.fhejl.pubtran.FavouritesActivity" />
        <service
            android:name="cz.fhejl.pubtran.MapDownloaderService" />
        <uses-library
            android:name="com.google.android.maps" />
    </application>

    <uses-sdk
        android:minSdkVersion="7"
        android:targetSdkVersion="8" />

    <uses-permission
        android:name="android.permission.ACCESS_FINE_LOCATION" />
    <uses-permission
        android:name="android.permission.BROADCAST_STICKY" />
    <uses-permission
        android:name="android.permission.INTERNET" />
    <uses-permission
        android:name="android.permission.WRITE_EXTERNAL_STORAGE" />

    <uses-feature
        android:name="android.hardware.location.network"
        android:required="false" />
    <uses-feature
        android:name="android.hardware.location.gps"
        android:required="false" />
    <uses-feature
        android:name="android.hardware.touchscreen"
        android:required="true" />
</manifest>
  • 0
    Какой тип телефона, производитель
  • 0
    К сожалению, отчет не содержит никакой другой информации, кроме трассировки стека.
Показать ещё 2 комментария
Теги:

2 ответа

3

У вас возникла такая проблема сегодня после обновления до последнего ADT/SDK. Кроме того, для меня исключение было

Unable to instantiate activity

Взял меня довольно долго. Проверено, что я использовал google-apis (для карт), использует-библиотеку, очистил проект и т.д.

Удаление .project и добавление нового (создайте новый проект для Android), наконец, решило его.

0

Создает ли подкласс класса CustomMainActivity MapActivity? Если это так, это может быть вызвано запуском вашего приложения на устройстве Android, у которого нет API-интерфейсов Google (я его не тестировал), или в противном случае отсутствует /system/framework/com.google.android.maps.jar.

Это достаточно просто проверить на эмуляторе - просто создайте AVD без API Google.

Фил Лелло

  • 0
    CustomMainActivity не наследует MapActivity, но я использую Google Maps в одном из своих занятий. Однако, когда устройство не имеет API Google, установка должна завершиться неудачей, я думаю ...
  • 0
    Я в тупике. Как появился этот отчет? Было ли это автоматизировано? Если вы не общаетесь с репортером, и это не автоматический отчет, то это может быть результатом того, что кто-то вмешивается в приложение - обычный пользователь не увидит следы стека. В любом случае, без какого-либо контакта с репортером для получения более подробной информации (например, устройство, версия для Android, приложения Google), я не думаю, что вы сможете пойти дальше.
Показать ещё 3 комментария

Ещё вопросы

Сообщество Overcoder
Наверх
Меню