ADT 更新后的 ClassNotFoundException

Posted

技术标签:

【中文标题】ADT 更新后的 ClassNotFoundException【英文标题】:ClassNotFoundException after ADT update 【发布时间】:2013-05-12 16:32:57 【问题描述】:

我最近将 android SDK 和 Eclipse ADT 插件更新到最新版本。现在,当我尝试运行预先存在的 Android 项目时,LogCat 显示ClassNotFoundException

我尝试创建一个新设备,但问题仍然存在。

清单

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

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

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

<application
    android:allowBackup="true"
    android:icon="@drawable/ic_launcher"
    android:label="@string/app_name"
    android:theme="@style/AppTheme" >
    <activity
        android:name="com.example.myapp.MainActivity"
        android:label="@string/app_name"
        android:windowSoftInputMode="stateHidden" >
        <intent-filter>
            <action android:name="android.intent.action.MAIN" />

            <category android:name="android.intent.category.LAUNCHER" />
        </intent-filter>
    </activity>
</application>

LogCat

05-17 13:09:56.357: E/AndroidRuntime(969): FATAL EXCEPTION: main
05-17 13:09:56.357: E/AndroidRuntime(969): java.lang.RuntimeException: Unable to instantiate activity ComponentInfocom.example.myapp/com.example.myapp.MainActivity: java.lang.ClassNotFoundException: Didn't find class "com.example.myapp.MainActivity" on path: /data/app/com.example.myapp-1.apk
05-17 13:09:56.357: E/AndroidRuntime(969):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2106)
05-17 13:09:56.357: E/AndroidRuntime(969):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
05-17 13:09:56.357: E/AndroidRuntime(969):  at android.app.ActivityThread.access$600(ActivityThread.java:141)
05-17 13:09:56.357: E/AndroidRuntime(969):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
05-17 13:09:56.357: E/AndroidRuntime(969):  at android.os.Handler.dispatchMessage(Handler.java:99)
05-17 13:09:56.357: E/AndroidRuntime(969):  at android.os.Looper.loop(Looper.java:137)
05-17 13:09:56.357: E/AndroidRuntime(969):  at android.app.ActivityThread.main(ActivityThread.java:5041)
05-17 13:09:56.357: E/AndroidRuntime(969):  at java.lang.reflect.Method.invokeNative(Native Method)
05-17 13:09:56.357: E/AndroidRuntime(969):  at java.lang.reflect.Method.invoke(Method.java:511)
05-17 13:09:56.357: E/AndroidRuntime(969):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
05-17 13:09:56.357: E/AndroidRuntime(969):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
05-17 13:09:56.357: E/AndroidRuntime(969):  at dalvik.system.NativeStart.main(Native Method)
05-17 13:09:56.357: E/AndroidRuntime(969): Caused by: java.lang.ClassNotFoundException: Didn't find class "com.example.myapp.MainActivity" on path: /data/app/com.example.myapp-1.apk
05-17 13:09:56.357: E/AndroidRuntime(969):  at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:65)
05-17 13:09:56.357: E/AndroidRuntime(969):  at java.lang.ClassLoader.loadClass(ClassLoader.java:501)
05-17 13:09:56.357: E/AndroidRuntime(969):  at java.lang.ClassLoader.loadClass(ClassLoader.java:461)
05-17 13:09:56.357: E/AndroidRuntime(969):  at android.app.Instrumentation.newActivity(Instrumentation.java:1054)
05-17 13:09:56.357: E/AndroidRuntime(969):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097)
05-17 13:09:56.357: E/AndroidRuntime(969):  ... 11 more

我注意到新的 APK 文件名为 myapp-1.apk,而通常称为 myapp.apk。 谁能告诉我如何解决?

【问题讨论】:

你指的是你的android项目中的任何库项目 @Raghunandan 我是。有什么问题吗? 不,我只有 libs 文件夹中的罐子。 ClassNotFoundException on AndroidAnnotations generated classes since update to ADT 22 的可能重复项 【参考方案1】:

尝试转到 Project -> Properties -> Java Build Path -> Order & Export 并确保为您的项目和所有项目检查 Android Private Libraries您正在使用的其他库项目。之后清理所有项目,看看会发生什么。

【讨论】:

什么是 Android 私有库?是否与上一个 ADT 一起引入? 我第二个@blackbelt 的问题。谷歌真的没有地方告诉我们 ADT 版本的新功能和重大变化吗? ADT 22 并不是 ADT 20 的噩梦,但为什么不至少告诉我们一些重大变化呢? The ADT Plug-in page 是我希望找到它的地方。 世界***工程师 (Google) 推出了破坏性的更新,这真是太好了。对不起,不禁感到尖酸刻薄。没有堆栈就会丢失。 在这上面浪费了几个小时。你是救生员。 >_ 【参考方案2】:

我知道我很晚才在这里发表回复。 Krauxe 提到的解决方法对我没有帮助。我的项目有两个库项目和两个罐子。我在Libraries do not get added to APK anymore after upgrade to ADT 22页面找到了“laaptu”发布的解决方案。

【讨论】:

【参考方案3】:

我有 Eclipse ADT 捆绑包和 @Krauxe 答案的补充,更新 Eclipse .project 文件如下为我工作:

<?xml version="1.0" encoding="UTF-8"?>
<projectDescription>
    <name>RedbeaconPro</name>
    <comment></comment>
    <projects>
    </projects>
    <buildSpec>
        <buildCommand>
            <name>com.android.ide.eclipse.adt.ResourceManagerBuilder</name>
            <arguments>
            </arguments>
        </buildCommand>
        <buildCommand>
            <name>com.android.ide.eclipse.adt.PreCompilerBuilder</name>
            <arguments>
            </arguments>
        </buildCommand>
        <buildCommand>
            <name>org.eclipse.jdt.core.javabuilder</name>
            <arguments>
            </arguments>
        </buildCommand>
        <buildCommand>
            <name>com.android.ide.eclipse.adt.ApkBuilder</name>
            <arguments>
            </arguments>
        </buildCommand>
    </buildSpec>
    <natures>
        <nature>com.android.ide.eclipse.adt.AndroidNature</nature>
        <nature>org.eclipse.jdt.core.javanature</nature>
    </natures>
</projectDescription>

【讨论】:

【参考方案4】:

如果您也在项目中使用 Maven 插件,“Maven -> Maven Update...”可能会导致与 ClassNotFoundException 相同的问题。如您所知,默认的类输出文件夹应该是在 .classpath 文件和 Eclipse 构建路径中指定的 /bin/classes。但是一旦你执行“Maven->Maven Update...”,输出文件夹将被设置为“target/classes”。您可以在 .classpath 文件中找到它(output="target/classes")。

.classpath 文件:

...    
<classpath>
            <classpathentry kind="src" path="gen"/>
            <classpathentry kind="src" output="target/classes" path="src/main/java">
...

如何解决此问题请在 pom.xml 文件中明确指定类输出文件夹为“bin/classes”

pom.xml 文件:

...
<build>
            <sourceDirectory>src/main/java</sourceDirectory>
            <outputDirectory>bin/classes</outputDirectory>
...

【讨论】:

以上是关于ADT 更新后的 ClassNotFoundException的主要内容,如果未能解决你的问题,请参考以下文章

与大家分享robotium一个小问题。Test run failed:Instrumentation run failed due to 'java.lang.ClassNotFoundExc

线程“main”中的异常 java.lang.NoClassDefFoundError: kotlin/KotlinPackage & 由:java.lang.ClassNotFoundExc

ADT 更新错误

如何解决Eclipse更新ADT或者更新SDK的问题

adt无法导出pdbqt

此 Android SDK 需要 ADT 版本 23.0.0 或更高版本。当前版本是 22.6。请更新 ADT 到最新版本? [复制]