2014-01-10 46 views
3

首先,用一张图片(我的IDE的打印屏幕),它会更容易显示我的包和文件,但是当我试图提交我的问题时,系统说“您至少需要10个声望才能发布图片“这是什么意思?Android ClassNotFoundException:没有找到类MainActivity

我使用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没有错误(从Package Explorer视图)和该类名称是MainActivity。

娄我AndroidManifest.xml文件的内容(问题来自活动安卓名)

<?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> 
+0

尝试清洁并重新构建项目 – Keerthivasan

+0

清理项目,然后再次运行它。 – Piyush

+0

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

回答

4

您正在使用Maven插件在你的项目中,“Maven的 - > Maven的更新......”会导致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 /班”。

pom.xml文件:

... 
<build> 
      <sourceDirectory>src/main/java</sourceDirectory> 
      <outputDirectory>bin/classes</outputDirectory> 
... 
相关问题