【问题标题】:android ClassNotFoundException: Didn't find class MainActivityandroid ClassNotFoundException:找不到类 MainActivity
【发布时间】:2014-01-10 10:28:33
【问题描述】:

首先,使用图片(我的 IDE 的打印屏幕)显示我的包和文件会更容易,但是当我尝试提交我的问题时,系统会说“您需要至少 10 个声望才能发布图像“ 那是什么意思 ?????

我使用 Eclipse Juno 和 Google 的 ADT 插件来开发 Android 应用程序。

起初,没问题,我可以在模拟器甚至我的 Android 设备上运行我的应用程序。

只有在我为 Maven 添加了 Eclipse 插件之后,问题才开始出现。 这是插件“Android 开发工具和 m2eclipse 的集成” Maven2 插件版本 0.4.3"

从那时起,我已经尝试了一切,已经花费了太多时间而无法继续前进。

在运行时我得到这个异常:

01-10 09:56:17.804: E/Trace(1180): error opening trace file: No such file or directory (2)
01-10 09:56:17.914: D/AndroidRuntime(1180): Shutting down VM
01-10 09:56:17.914: W/dalvikvm(1180): threadid=1: thread exiting with uncaught exception (group=0x40a71930)
01-10 09:56:17.935: E/AndroidRuntime(1180): FATAL EXCEPTION: main
01-10 09:56:17.935: E/AndroidRuntime(1180): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.example.shoppinglist2/com.example.shoppinglist2.MainActivity}: java.lang.ClassNotFoundException: Didn't find class "com.example.shoppinglist2.MainActivity" on path: /data/app/com.example.shoppinglist2-1.apk
01-10 09:56:17.935: E/AndroidRuntime(1180):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2106)
01-10 09:56:17.935: E/AndroidRuntime(1180):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2230)
01-10 09:56:17.935: E/AndroidRuntime(1180):     at android.app.ActivityThread.access$600(ActivityThread.java:141)
01-10 09:56:17.935: E/AndroidRuntime(1180):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1234)
01-10 09:56:17.935: E/AndroidRuntime(1180):     at android.os.Handler.dispatchMessage(Handler.java:99)
01-10 09:56:17.935: E/AndroidRuntime(1180):     at android.os.Looper.loop(Looper.java:137)
01-10 09:56:17.935: E/AndroidRuntime(1180):     at android.app.ActivityThread.main(ActivityThread.java:5041)
01-10 09:56:17.935: E/AndroidRuntime(1180):     at java.lang.reflect.Method.invokeNative(Native Method)
01-10 09:56:17.935: E/AndroidRuntime(1180):     at java.lang.reflect.Method.invoke(Method.java:511)
01-10 09:56:17.935: E/AndroidRuntime(1180):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:793)
01-10 09:56:17.935: E/AndroidRuntime(1180):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:560)
01-10 09:56:17.935: E/AndroidRuntime(1180):     at dalvik.system.NativeStart.main(Native Method)
01-10 09:56:17.935: E/AndroidRuntime(1180): Caused by: java.lang.ClassNotFoundException: Didn't find class "com.example.shoppinglist2.MainActivity" on path: /data/app/com.example.shoppinglist2-1.apk
01-10 09:56:17.935: E/AndroidRuntime(1180):     at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:65)
01-10 09:56:17.935: E/AndroidRuntime(1180):     at java.lang.ClassLoader.loadClass(ClassLoader.java:501)
01-10 09:56:17.935: E/AndroidRuntime(1180):     at java.lang.ClassLoader.loadClass(ClassLoader.java:461)
01-10 09:56:17.935: E/AndroidRuntime(1180):     at android.app.Instrumentation.newActivity(Instrumentation.java:1054)
01-10 09:56:17.935: E/AndroidRuntime(1180):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2097)
01-10 09:56:17.935: E/AndroidRuntime(1180):     ... 11 more

如果我可以添加图片,您会看到包 com.example.shoppinglist2 中没有错误(从包资源管理器视图),并且类名称是 MainActivity。

下面是我的 AndroidManifest.xml 文件的内容(问题来自活动 android:name)

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

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

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

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

</manifest> 

【问题讨论】:

  • 尝试清理并重新构建项目
  • 清理你的项目并再次运行它。
  • 如果我可以添加图片,您会看到 com.example.shoppinglist2 包(从包资源管理器视图)中没有错误,并且类名为 MainActivity。
  • 重启 eclipse 并清理你的项目并再次运行它...
  • 重建,清理项目并重新启动eclipse..还要确保该类存在于路径中,并且也在manifest.xml中

标签: java android eclipse maven


【解决方案1】:

您在项目中使用了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>
...

【讨论】:

    猜你喜欢
    • 2015-05-05
    • 2014-01-22
    • 2017-04-14
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多