![](/img/trans.png)
[英]Android ClassNotFoundException: Didn't find class on path
[英]android ClassNotFoundException: Didn't find class MainActivity
首先,使用圖片(我的IDE的打印屏幕)顯示我的包和文件會更容易但是當我嘗試提交我的問題時,系統會說“你需要至少10個聲望才能發布圖片”那意思是?????
我使用Eclipse Juno和谷歌的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。
Bellow我的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>
您在項目中使用Maven插件,“Maven - > Maven Update ...”可能會導致ClassNotFoundException出現問題。 如您所知,默認類輸出文件夾應該是/ bin / classes,它在.classpath文件和Eclipse Build Path中指定。 但是一旦你執行“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>
...
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.