Android - 无法实例化活动

时间:2013-12-27 19:21:42

标签: java android android-studio updates

我目前正在使用Android Studio开发自己的Android项目(我的自定义启动器)!问题是,自从上次更新(到版本0.4.0)后,我无法运行我的应用程序。

相反,我收到以下错误:

FATAL EXCEPTION: main
    java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.natercio.myhome/com.natercio.myhome.Launcher}: java.lang.ClassNotFoundException: Didn't find class "com.natercio.myhome.Launcher" on path: DexPathList[[zip file "/data/app/com.natercio.myhome-2.apk"],nativeLibraryDirectories=[/data/app-lib/com.natercio.myhome-2, /system/lib]]
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2137)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261)
            at android.app.ActivityThread.access$600(ActivityThread.java:141)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)
            at android.os.Handler.dispatchMessage(Handler.java:99)
            at android.os.Looper.loop(Looper.java:137)
            at android.app.ActivityThread.main(ActivityThread.java:5103)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:525)
            at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
            at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
            at dalvik.system.NativeStart.main(Native Method)
     Caused by: java.lang.ClassNotFoundException: Didn't find class "com.natercio.myhome.Launcher" on path: DexPathList[[zip file "/data/app/com.natercio.myhome-2.apk"],nativeLibraryDirectories=[/data/app-lib/com.natercio.myhome-2, /system/lib]]
            at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:53)
            at java.lang.ClassLoader.loadClass(ClassLoader.java:501)
            at java.lang.ClassLoader.loadClass(ClassLoader.java:461)
            at android.app.Instrumentation.newActivity(Instrumentation.java:1061)
            at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2128)
            at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261)
            at android.app.ActivityThread.access$600(ActivityThread.java:141)
            at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)
            at android.os.Handler.dispatchMessage(Handler.java:99)
            at android.os.Looper.loop(Looper.java:137)
            at android.app.ActivityThread.main(ActivityThread.java:5103)
            at java.lang.reflect.Method.invokeNative(Native Method)
            at java.lang.reflect.Method.invoke(Method.java:525)

我已经搜索过任何我能记住的解决方案(或相关的东西),并尝试了一堆已经没有任何成功的东西。

  • 检查“compiler.xml”(没有排除)
  • 清理/构建(错误仍然存​​在)
  • 检查“AndroidManifest.xml”(一切似乎都正确)
  • 重新创建整个项目(仅导入代码和资源,但错误仍然存​​在)

我在这一行注意到了一件事

Caused by: java.lang.ClassNotFoundException: Didn't find class "com.natercio.myhome.Launcher" on path: DexPathList[[zip file "/data/app/com.natercio.myhome-2.apk"],nativeLibraryDirectories=[/data/app-lib/com.natercio.myhome-2, /system/lib]]

是有一个“-2”(有时是“-1”)附加到应用程序的名称(在apk文件和lib路径中)但我从来没有真正注意到这一点,所以我可以不确定这是否与我的问题有关。

还请注意我使用git并且我已经尝试将任何更改还原到我以前的稳定提交之一。

更新

还有其他人在Android Studio中遇到此问题吗?是否有任何其他解决方案,我错过了这种错误,或者这可能是最新的Android插件(Android工作室)中的一些错误。

UPDATE(build.gradle& manifest文件):

的build.gradle:

buildscript {
    repositories {
        mavenCentral()
    }
    dependencies {
        classpath 'com.android.tools.build:gradle:0.7.+'
    }
}
apply plugin: 'android'

repositories {
    mavenCentral()
}

android {
    compileSdkVersion 18
    buildToolsVersion '18.1.1'

    defaultConfig {
        minSdkVersion 15
        targetSdkVersion 19
        versionCode 1
        versionName "1.0"
    }

    compileOptions {
        sourceCompatibility JavaVersion.VERSION_1_7
        targetCompatibility JavaVersion.VERSION_1_7
    }
    buildTypes {
        release {
            runProguard false
            proguardFiles getDefaultProguardFile('proguard-android.txt'), 'proguard-rules.txt'
        }
    }
}

dependencies {
    compile 'com.android.support:support-v4:+'
    compile 'com.android.support:support-v13:+'
    compile 'com.j256.ormlite:ormlite-android:4.47'
}

的AndroidManifest.xml:

<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
          package="com.natercio.myhome"
          android:versionName="@string/app_version_name">

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

    <uses-permission android:name="android.permission.SET_WALLPAPER"/>
    <uses-permission android:name="android.permission.ACCESS_WIFI_STATE" />
    <uses-permission android:name="android.permission.ACCESS_NETWORK_STATE" />

    <application
            android:icon="@drawable/ic_launcher"
            android:label="@string/app_name"
            android:theme="@style/Theme.Launcher">

        <service android:name=".profiler.ProfilerService"
                 android:exported="false"/>

        <activity android:name=".Launcher"
                  android:screenOrientation="portrait"
                  android:launchMode="singleTask"
                  android:description="@string/app_description">

            <intent-filter>
                <action android:name="android.intent.action.MAIN"/>
                <category android:name="android.intent.category.HOME"/>
                <category android:name="android.intent.category.DEFAULT"/>
            </intent-filter>

        </activity>

    </application>

</manifest>

6 个答案:

答案 0 :(得分:2)

将Android Studio更新为0.4.0后,我遇到了同样的问题。这看起来过于简单,但我通过简单地删除我的整个/构建文件夹(在0.4.0更新之前创建的文件夹)和重建来解决了这个问题。

答案 1 :(得分:2)

试试这个 java.lang.RuntimeException: Unable to instantiate activity ComponentInfo / java.lang.ClassNotFoundException

,或者 使用CMD访问项目并清理项目

gradlew clean

gradlew build

答案 2 :(得分:0)

-2或-1来自我相信的多份副本?至少这就是我的经验。但你的问题到底是什么?

答案 3 :(得分:0)

错误表明您在项目中使用的库中有一个库的多个副本。进入project structure - &gt; modules并检查targetapk-libs文件夹,如果android studio正在提取多个副本。我在android studio中遇到了同样的错误,结果发现工作室在名为target的{​​{1}}文件夹中生成了一个新文件夹,导致了问题。

答案 4 :(得分:0)

问题在android studio更新后自行解决了!

答案 5 :(得分:0)

检查您的项目设置 - &gt; modules-&gt;您的项目名称 - &gt;来源

确保你的src和res列表在右边框架上(名为Add Content Root,res as Resources Folders,src as Sources Folders)

或者你的项目遇到一些错误,愚蠢的android工作室仍然把错误的apk放在你的设备上然后运行当然得到了错误。