java.lang.RuntimeException: 无法实例化活动 ComponentInfo/ ClassNotFoundException

14
我正在开发Android应用程序,现在想要添加新的活动(Activity),但我的LogCat中出现了错误。

我的LogCat:

04-19 12:59:17.654: D/AndroidRuntime(18135): Shutting down VM
04-19 12:59:17.654: W/dalvikvm(18135): threadid=1: thread exiting with uncaught exception (group=0x4001d878)
04-19 12:59:17.684: E/AndroidRuntime(18135): FATAL EXCEPTION: main
04-19 12:59:17.684: E/AndroidRuntime(18135): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.bvblogic.android.batterypower/com.bvblogic.android.batterypower.activities.UnlockActivity}: java.lang.ClassNotFoundException: com.bvblogic.android.batterypower.activities.UnlockActivity in loader dalvik.system.PathClassLoader[/data/app/com.bvblogic.android.batterypower-1.apk]
04-19 12:59:17.684: E/AndroidRuntime(18135):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2587)
04-19 12:59:17.684: E/AndroidRuntime(18135):    at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2681)
04-19 12:59:17.684: E/AndroidRuntime(18135):    at android.app.ActivityThread.access$2300(ActivityThread.java:125)
04-19 12:59:17.684: E/AndroidRuntime(18135):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
04-19 12:59:17.684: E/AndroidRuntime(18135):    at android.os.Handler.dispatchMessage(Handler.java:99)
04-19 12:59:17.684: E/AndroidRuntime(18135):    at android.os.Looper.loop(Looper.java:123)
04-19 12:59:17.684: E/AndroidRuntime(18135):    at android.app.ActivityThread.main(ActivityThread.java:4640)
04-19 12:59:17.684: E/AndroidRuntime(18135):    at java.lang.reflect.Method.invokeNative(Native Method)
04-19 12:59:17.684: E/AndroidRuntime(18135):    at java.lang.reflect.Method.invoke(Method.java:521)
04-19 12:59:17.684: E/AndroidRuntime(18135):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
04-19 12:59:17.684: E/AndroidRuntime(18135):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
04-19 12:59:17.684: E/AndroidRuntime(18135):    at dalvik.system.NativeStart.main(Native Method)
04-19 12:59:17.684: E/AndroidRuntime(18135): Caused by: java.lang.ClassNotFoundException: com.bvblogic.android.batterypower.activities.UnlockActivity in loader dalvik.system.PathClassLoader[/data/app/com.bvblogic.android.batterypower-1.apk]
04-19 12:59:17.684: E/AndroidRuntime(18135):    at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:243)
04-19 12:59:17.684: E/AndroidRuntime(18135):    at java.lang.ClassLoader.loadClass(ClassLoader.java:573)
04-19 12:59:17.684: E/AndroidRuntime(18135):    at java.lang.ClassLoader.loadClass(ClassLoader.java:532)
04-19 12:59:17.684: E/AndroidRuntime(18135):    at android.app.Instrumentation.newActivity(Instrumentation.java:1021)
04-19 12:59:17.684: E/AndroidRuntime(18135):    at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2579)
04-19 12:59:17.684: E/AndroidRuntime(18135):    ... 11 more

我的manifest.xml

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

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

    <uses-permission android:name="android.permission.INTERNET" />
    <uses-permission android:name="android.permission.BATTERY_STATS" />
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
    <uses-permission android:name="android.permission.UPDATE_DEVICE_STATS" />
    <uses-permission android:name="android.permission.CHANGE_WIFI_STATE" />
    <uses-permission android:name="android.permission.WAKE_LOCK" />
    <uses-permission android:name="android.permission.BLUETOOTH" />
    <uses-permission android:name="android.permission.BLUETOOTH_ADMIN" />
    <uses-permission android:name="android.permission.WRITE_SETTINGS" />
    <uses-permission android:name="android.permission.HARDWARE_TEST" />
    <uses-permission android:name="android.permission.RESTART_PACKAGES" />
    <uses-permission android:name="android.permission.KILL_BACKGROUND_PROCESSES" />
    <uses-permission android:name="android.permission.GET_PACKAGE_SIZE" />
    <uses-permission android:name="android.permission.WAKE_LOCK" />
    <uses-permission android:name="android.permission.READ_PHONE_STATE" />
    <uses-permission android:name="android.permission.SYSTEM_ALERT_WINDOW" />

    <application
        android:icon="@drawable/ic_launcher"
        android:label="@string/app_name"
        android:theme="@style/AppTheme" >
        <activity android:name=".activities.UnlockActivity">
            <intent-filter>
                <action android:name="android.intent.action.MAIN" />

                <category android:name="android.intent.category.LAUNCHER" />
            </intent-filter>
        </activity>
        <activity android:name="com.bvblogic.android.batterypower.activities.BatteryPowerTabActivity" >
        </activity>
        <activity android:name="com.bvblogic.android.batterypower.activities.MonitoringActivity" >
        </activity>
        <activity android:name="com.bvblogic.android.batterypower.activities.SettingsActivity" >
        </activity>
        <activity android:name="com.bvblogic.android.batterypower.activities.ProcessManagerActivity" >
        </activity>
        <activity
            android:name="com.bvblogic.android.batterypower.activities.DummyBrightnessActivity"
            android:excludeFromRecents="true"
            android:taskAffinity="com.bvblogic.android.batterypower.Dummy"
            android:theme="@android:style/Theme.Translucent.NoTitleBar" >
        </activity>

        <service android:name="com.bvblogic.android.batterypower.util.TurboBoost" >
        </service>
        <service android:name="com.bvblogic.android.batterypower.services.BatteryPowerService" />

        <receiver
            android:name="com.bvblogic.android.batterypower.alarm.RegistrationAlarm"
            android:process=":registration" >
        </receiver>
        <receiver
            android:name="com.bvblogic.android.batterypower.alarm.OnlinePingAlarm"
            android:process=":ping" >
        </receiver>
        <receiver
            android:name="com.bvblogic.android.batterypower.alarm.AdNotificationAlarm"
            android:process=":remote" >
        </receiver>
        <receiver
            android:name="com.bvblogic.android.batterypower.widget.MWidgetProvider"
            android:icon="@drawable/btn_remove"
            android:label="@string/app_name" >
            <intent-filter>
                <action android:name="android.appwidget.action.APPWIDGET_UPDATE" />
            </intent-filter>

            <meta-data
                android:name="android.appwidget.provider"
                android:resource="@xml/widget_provider" />
        </receiver>
    </application>

</manifest>

我的活动:

package com.bvblogic.android.batterypower.activities;

import com.bvblogic.android.batterypower.R;

import android.app.Activity;
import android.os.Bundle;
import android.util.Log;

public class UnlockActivity extends Activity {  
    @Override
    protected void onCreate(Bundle savedInstanceState) {
        // TODO Auto-generated method stub
        super.onCreate(savedInstanceState);
        setContentView(R.layout.settings_auto_saving_layout);
    }
}

然后我将Intent-Filter指定给BatteryPowerTabActivity,应用程序成功启动。请帮我。谢谢。

10个回答

19

升级时,新的“Android私有库”的“排序和导出”并未始终被选中。而android-support-v4.jar现在位于此“Android私有库”部分。

要解决此问题,请进入“排序和导出”选项,并勾选“Android私有库”。然后刷新/清理/重建。

对于库项目完成此“修复”后,您可能需要关闭并重新打开任何依赖项目,因为它们可能无法立即看到这个“修复”。

输入图像描述


对我来说,问题出在“顺序和导出”中:将我的 /src 和 /gen 移动到列表的顶部 #fml - jackocnr
在再次遇到这个问题后,我认为实际上是删除了我的 out/ 目录(在我的 PhoneGap 项目中,该目录位于 platforms/android/out/)。 - jackocnr

7
将您在清单文件中的活动声明更改为:
 <activity android:name=".UnlockActivity">

否则
<activity android:name="Yourcompletepackagename.UnlockActivity">

并尝试


嗨,谢谢你的回答。但是当我启动应用程序时它崩溃了。 - a.black13
这一次你的Logcat说了什么? - vinoth
请确保您在清单文件中声明的所有活动和服务的类名正确无误。 - vinoth
4
我花了10个小时来解决这个问题。理解这个问题是在更新ADT Eclipse插件之后出现的。 - a.black13
所有类都已声明。问题是我正在添加新的活动(在这种情况下是UnlockActivity)。 - a.black13

5

如果您的活动类位于默认包中,则可能会发生这种情况。我通过将活动类移动到新包中并更改manifest.xml来修复它。

之前

activity android:name=".MainActivity"

之后

activity android:name="new_package.MainActivity"


5

伙计,这也发生在我发布应用程序到市场后。这是一场彻底的灾难。我在已经发布5个小时之后才意识到这一点。

使用ADT运行时没有问题,问题出在生成的APK上。因此,如果您发布一个应用程序,请在测试手机上测试纯APK的安装。

和你一样,我认为问题出在我的ADT更新上,在我的情况下是v22。

解决方案是清理和构建项目:

Android java.lang.RuntimeException: Unable to instantiate activity ComponentInfo


我很高兴找到了你的解决方案 - 这正是我的情况。我只需要重新构建和创建我的 .apk 文件。 - jtooker

3

我曾经遇到相同的问题,但我在清单文件中声明了我的活动,并使用了正确的名称。

我的问题在于我没有将第三方库导入“libs”文件夹,并且需要在项目中引用它们(右键单击,属性,Java Build Path,库,添加Jar...)。

关于如何在清单文件中声明活动,只要该活动位于主包中,就始终正确使用.ActivityName。


1
我也遇到了同样的问题,我只是关闭了自动构建,手动构建我的Android项目并清理了我的项目,这为我解决了这个错误。

嗨,感谢您对解决方案的关注。许多问题可以通过清理和重建项目来解决。 - a.black13

1

我同意 @codercat 给你的建议,但是当你在同一项目结构中使用v7和v13来完成不同的功能时,这个错误也会出现。因此,我的建议是将v13 jar文件复制到libs文件夹中(不要将它作为外部jar导入),然后检查Android库 Android依赖项。刷新你的项目,然后清理你的项目。我相信你面临的错误将会消失。


嗨。在这个项目中(一年前开发),我没有使用任何兼容性库。谢谢你的回答+1。 - a.black13

0

将行更改为

<activity android:name=".activities.UnlockActivity">  

<activity android:name=".com.bvblogic.android.batterypower.activities.UnlockActivity
 ">

我解决了我的问题。它很简单,只需要进入Project>Properties>Builders并勾选所有复选框即可。谢谢大家。 - a.black13

0

你可能已经声明了String a = edt.getText().toString();或int 5/3,因此会出现这样的错误。

所以,在onCreate方法中声明它们,错误将得到解决。


0

清理项目对我有用。你可能会问我是什么导致了这个问题?哈哈,我试图将一个项目从4.4升级到Android 5,然后改变主意,试图将其恢复回KitKat,然后哇!就出现了这个错误。


网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接