由于我无法识别的活动错误,我的应用程序崩溃

Posted

技术标签:

【中文标题】由于我无法识别的活动错误,我的应用程序崩溃【英文标题】:My app Crashes due to an Activity error i can't identify 【发布时间】:2015-09-17 23:50:50 【问题描述】:

这是我一直在尝试制作的应用程序,但是当我尝试运行它时它崩溃了... LogCat 上的大多数错误都表明存在“java.lang.RuntimeException:无法实例化活动 ComponentInfo com.greed/com.greed.GreedActivity" 这是我的清单文件,是不是我做错了什么。

附:我用的是eclipse我还没有迁移到android Studio。

我的完整 LogCat 是这样的:

07-01 10:31:57.823: D/AndroidRuntime(3536): Shutting down VM
07-01 10:31:57.823: W/dalvikvm(3536): threadid=1: thread exiting with uncaught exception (group=0x416b5d40)
07-01 10:31:57.834: E/AndroidRuntime(3536): FATAL EXCEPTION: main
07-01 10:31:57.834: E/AndroidRuntime(3536): Process: com.greed, PID: 3536
07-01 10:31:57.834: E/AndroidRuntime(3536): java.lang.RuntimeException: Unable to instantiate activity ComponentInfocom.greed/com.greed.GreedActivity: java.lang.ClassNotFoundException: Didn't find class "com.greed.GreedActivity" on path: DexPathList[[zip file "/data/app/com.greed-1.apk"],nativeLibraryDirectories=[/data/app-lib/com.greed-1, /vendor/lib, /system/lib]]
07-01 10:31:57.834: E/AndroidRuntime(3536):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2135)
07-01 10:31:57.834: E/AndroidRuntime(3536):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2269)
07-01 10:31:57.834: E/AndroidRuntime(3536):     at android.app.ActivityThread.access$800(ActivityThread.java:139)
07-01 10:31:57.834: E/AndroidRuntime(3536):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1210)
07-01 10:31:57.834: E/AndroidRuntime(3536):     at android.os.Handler.dispatchMessage(Handler.java:102)
07-01 10:31:57.834: E/AndroidRuntime(3536):     at android.os.Looper.loop(Looper.java:136)
07-01 10:31:57.834: E/AndroidRuntime(3536):     at android.app.ActivityThread.main(ActivityThread.java:5102)
07-01 10:31:57.834: E/AndroidRuntime(3536):     at java.lang.reflect.Method.invokeNative(Native Method)
07-01 10:31:57.834: E/AndroidRuntime(3536):     at java.lang.reflect.Method.invoke(Method.java:515)
07-01 10:31:57.834: E/AndroidRuntime(3536):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:785)
07-01 10:31:57.834: E/AndroidRuntime(3536):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:601)
07-01 10:31:57.834: E/AndroidRuntime(3536):     at dalvik.system.NativeStart.main(Native Method)
07-01 10:31:57.834: E/AndroidRuntime(3536): Caused by: java.lang.ClassNotFoundException: Didn't find class "com.greed.GreedActivity" on path: DexPathList[[zip file "/data/app/com.greed-1.apk"],nativeLibraryDirectories=[/data/app-lib/com.greed-1, /vendor/lib, /system/lib]]
07-01 10:31:57.834: E/AndroidRuntime(3536):     at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:56)
07-01 10:31:57.834: E/AndroidRuntime(3536):     at java.lang.ClassLoader.loadClass(ClassLoader.java:497)
07-01 10:31:57.834: E/AndroidRuntime(3536):     at java.lang.ClassLoader.loadClass(ClassLoader.java:457)
07-01 10:31:57.834: E/AndroidRuntime(3536):     at android.app.Instrumentation.newActivity(Instrumentation.java:1084)
07-01 10:31:57.834: E/AndroidRuntime(3536):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2126)
07-01 10:31:57.834: E/AndroidRuntime(3536):     ... 11 more
07-01 10:32:02.763: I/Process(3536): Sending signal. PID: 3536 SIG: 9

清单:

<manifest package="com.greed"
    android:versionCode="1"
    android:versionName="1.0"
    android:installLocation="preferExternal"
    xmlns:android="http://schemas.android.com/apk/res/android">

    <uses-permission android:name="android.permission.WAKE_LOCK"/>
    <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE"/>
    <uses-sdk
        android:minSdkVersion="8"
        android:targetSdkVersion="19" />

    <application
        android:allowBackup="true"
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity
            android:name=".GreedActivity"
            android:label="Greed"
            android:screenOrientation="portrait">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />
                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
    </application>

</manifest>

【问题讨论】:

请发布您的堆栈跟踪以及您的活动代码 GreedActivity 在什么包里?它应该在 com.greed.GreedActivity 对不起,我对这个(它实际上是我的第一个应用程序)非常陌生,我在哪里可以找到这些? 我有 3 个包 com.androidgames.framework.impl、com.androidgames.framework 和 com.androidgames.greed 框架包含声音、图形、输入、FileIO 等内容。com.androidgames.greed 包含资产、加载屏幕、主屏幕和设置 【参考方案1】:

您没有一个名为 GreedActivity 的类作为您的启动器

或者清单文件中的包不正确

【讨论】:

感谢这解决了我的问题

以上是关于由于我无法识别的活动错误,我的应用程序崩溃的主要内容,如果未能解决你的问题,请参考以下文章

[标签比较:]:无法识别的选择器发送到实例

应用程序崩溃,错误无法识别选择器发送到实例

由于 MKPointAnnotation 上无法识别的选择器导致崩溃

错误:使用类引用时无法识别的选择器

崩溃:_finishDecodingLayoutGuideConnections:] 无法识别的选择器发送到实例

iPhone:“无法识别的选择器已发送到实例”错误