2012-01-30 42 views
1

我一直在閱讀其他誰已經有這個問題的解決方案,並且大多數答案都聲明它的清單存在問題,但是我看不到我的任何問題。看起來準確,但我一直運行得到一個ClassNotFoundException。Mysteriously persistent ClassNotFoundException(主要活動)

SongbirdActivity.java:

package com.songbirdapp.songbird; 

import android.app.Activity; 
import android.os.Bundle; 

public class SongbirdActivity extends Activity { 
    /** Called when the activity is first created. */ 
    @Override 
    public void onCreate(Bundle savedInstanceState) { 
     super.onCreate(savedInstanceState); 
     setContentView(R.layout.main); 
    } 
} 

AndroidManifest.xml中

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

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

    <application 
     android:icon="@drawable/ic_launcher" 
     android:label="@string/app_name" > 
     <activity 
      android:label="@string/app_name" 
      android:name=".SongbirdActivity" > 
      <intent-filter > 
       <action android:name="android.intent.action.MAIN" /> 

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


</manifest> 

任何人都可以在這裏看到了問題?

logcat的輸出:

01-30 15:28:21.622: D/AndroidRuntime(1315): Shutting down VM 
01-30 15:28:21.692: W/dalvikvm(1315): threadid=1: thread exiting with uncaught exception (group=0x409c01f8) 
01-30 15:28:21.712: E/AndroidRuntime(1315): FATAL EXCEPTION: main 
01-30 15:28:21.712: E/AndroidRuntime(1315): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.songbirdapp.songbird/com.songbirdapp.songbird.SongbirdActivity}: java.lang.ClassNotFoundException: com.songbirdapp.songbird.SongbirdActivity 
01-30 15:28:21.712: E/AndroidRuntime(1315):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1880) 
01-30 15:28:21.712: E/AndroidRuntime(1315):  at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1981) 
01-30 15:28:21.712: E/AndroidRuntime(1315):  at android.app.ActivityThread.access$600(ActivityThread.java:123) 
01-30 15:28:21.712: E/AndroidRuntime(1315):  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1147) 
01-30 15:28:21.712: E/AndroidRuntime(1315):  at android.os.Handler.dispatchMessage(Handler.java:99) 
01-30 15:28:21.712: E/AndroidRuntime(1315):  at android.os.Looper.loop(Looper.java:137) 
01-30 15:28:21.712: E/AndroidRuntime(1315):  at android.app.ActivityThread.main(ActivityThread.java:4424) 
01-30 15:28:21.712: E/AndroidRuntime(1315):  at java.lang.reflect.Method.invokeNative(Native Method) 
01-30 15:28:21.712: E/AndroidRuntime(1315):  at java.lang.reflect.Method.invoke(Method.java:511) 
01-30 15:28:21.712: E/AndroidRuntime(1315):  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784) 
01-30 15:28:21.712: E/AndroidRuntime(1315):  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551) 
01-30 15:28:21.712: E/AndroidRuntime(1315):  at dalvik.system.NativeStart.main(Native Method) 
01-30 15:28:21.712: E/AndroidRuntime(1315): Caused by: java.lang.ClassNotFoundException: com.songbirdapp.songbird.SongbirdActivity 
01-30 15:28:21.712: E/AndroidRuntime(1315):  at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:61) 
01-30 15:28:21.712: E/AndroidRuntime(1315):  at java.lang.ClassLoader.loadClass(ClassLoader.java:501) 
01-30 15:28:21.712: E/AndroidRuntime(1315):  at java.lang.ClassLoader.loadClass(ClassLoader.java:461) 
01-30 15:28:21.712: E/AndroidRuntime(1315):  at android.app.Instrumentation.newActivity(Instrumentation.java:1023) 
01-30 15:28:21.712: E/AndroidRuntime(1315):  at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1871) 
01-30 15:28:21.712: E/AndroidRuntime(1315):  ... 11 more 
+1

安置自己的logcat請 – Guillaume 2012-01-30 23:08:17

+0

logcat的包括 – zakdances 2012-01-30 23:17:10

+0

奇怪...該清單看起來好像沒什麼問題。嘗試從頭開始重建你的項目 – Guillaume 2012-01-30 23:55:55

回答

1

這個問題已經不顧一切試圖回答這個問題。我要將這個項目燒掉並重新開始,然後複製並粘貼舊的代碼。

0

我看到了相同的行爲,最終解決了這個問題,確保當我導出apk文件時,在該位置沒有一個現有的apk文件。當出現(例如,在稍微改變之後導出)時,apk通常會變得明顯更小(〜600k vs〜720k),一旦啓動,通常會導致此CallNotFoundException異常。

一旦我確定在導出之前刪除現有的APK,我就停止了這個討厭的問題。

也許這會幫助別人。

的Eclipse 4.2.0在Windows 7 ADT 21.0.0