アプリをフレームワーク ライブラリとアプリケーションにリファクタリングしたばかりですが、エミュレーターでアプリを起動しようとすると、次のエラー スタック トレースが表示されます。
06-02 18:22:35.529: E/AndroidRuntime(586): FATAL EXCEPTION: main
06-02 18:22:35.529: E/AndroidRuntime(586): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.matthewrathbone.eastersays/com.matthewrathbone.eastersays.EasterSimonSaysActivity}: java.lang.ClassNotFoundException: com.matthewrathbone.eastersays.EasterSimonSaysActivity in loader dalvik.system.PathClassLoader[/data/app/com.matthewrathbone.eastersays-1.apk]
06-02 18:22:35.529: E/AndroidRuntime(586): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2585)
06-02 18:22:35.529: E/AndroidRuntime(586): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2679)
06-02 18:22:35.529: E/AndroidRuntime(586): at android.app.ActivityThread.access$2300(ActivityThread.java:125)
06-02 18:22:35.529: E/AndroidRuntime(586): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2033)
06-02 18:22:35.529: E/AndroidRuntime(586): at android.os.Handler.dispatchMessage(Handler.java:99)
06-02 18:22:35.529: E/AndroidRuntime(586): at android.os.Looper.loop(Looper.java:123)
06-02 18:22:35.529: E/AndroidRuntime(586): at android.app.ActivityThread.main(ActivityThread.java:4627)
06-02 18:22:35.529: E/AndroidRuntime(586): at java.lang.reflect.Method.invokeNative(Native Method)
06-02 18:22:35.529: E/AndroidRuntime(586): at java.lang.reflect.Method.invoke(Method.java:521)
06-02 18:22:35.529: E/AndroidRuntime(586): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:868)
06-02 18:22:35.529: E/AndroidRuntime(586): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:626)
06-02 18:22:35.529: E/AndroidRuntime(586): at dalvik.system.NativeStart.main(Native Method)
06-02 18:22:35.529: E/AndroidRuntime(586): Caused by: java.lang.ClassNotFoundException: com.matthewrathbone.eastersays.EasterSimonSaysActivity in loader dalvik.system.PathClassLoader[/data/app/com.matthewrathbone.eastersays-1.apk]
06-02 18:22:35.529: E/AndroidRuntime(586): at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:243)
06-02 18:22:35.529: E/AndroidRuntime(586): at java.lang.ClassLoader.loadClass(ClassLoader.java:573)
06-02 18:22:35.529: E/AndroidRuntime(586): at java.lang.ClassLoader.loadClass(ClassLoader.java:532)
06-02 18:22:35.529: E/AndroidRuntime(586): at android.app.Instrumentation.newActivity(Instrumentation.java:1021)
06-02 18:22:35.529: E/AndroidRuntime(586): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2577)
06-02 18:22:35.529: E/AndroidRuntime(586): ... 11 more
通常、これはマニフェスト ファイルが何らかの点で間違っていることを意味しますが、考えられるすべてのことを再確認しました。
私のアクティビティクラスは次のとおりです。
package com.matthewrathbone.eastersays;
import android.os.Bundle;
import com.rathboma.simonsays.Assets.Season;
import com.rathboma.simonsays.SeasonPicker;
import com.rathboma.simonsays.SimonSaysActivity;
public class EasterSimonSaysActivity extends SimonSaysActivity {
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
}
@Override
protected void onDestroy() {
// TODO Auto-generated method stub
super.onDestroy();
}
@Override
public SeasonPicker getSeasonPicker() {
return new SeasonPicker(){
@Override
public Season getSeason() {
// TODO Auto-generated method stub
return Season.EASTER;
}
};
}
}
ご覧のとおり、マニフェストに正しくリストされています。
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="com.matthewrathbone.eastersays"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk android:minSdkVersion="7" android:targetSdkVersion="15" />
<application
android:icon="@drawable/ic_launcher"
android:label="@string/app_name" >
<activity
android:name=".EasterSimonSaysActivity"
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>
これを修正する方法がわかりません。どなたか助けていただければ幸いです。SO で同様の質問を多数調べましたが、この特定の動作は見つかりませんでした。
より詳しい情報:
- 生成されたAPK内を確認したところ、classes.dexファイルにクラスエントリがありました。
- Eclipseでプロジェクトをクリーンアップ/ビルドしてみました
- APKのコピーがまだ入っていない全く新しいデバイスイメージを使ってみました
- ライブラリプロジェクトを通常のJavaに変更し、その後Androidプロジェクトに戻しましたが、違いはありません
- 抽象 SimonSaysActivity をマニフェストに追加しても違いはありません。
- すべての依存関係をAndroidライブラリプロジェクトにして、必要なAndroidバージョンを同期してみましたが、役に立ちませんでした
解決策が見つかりました (下記参照)。回答/コメントを投稿した皆さんへ: 皆さんは素晴らしいです。問題を解決するのを手伝ってくれてありがとう!
これは SDK ツールのアップグレードによって導入されたようです。このリンクのコメント欄にコメントを寄せてくれた @Nick に感謝します。http://iqadd.com/item/noclassdeffounderror-adt-fix
ベストアンサー1
私は自分のプロジェクトでしばらく遊んでみましたが、あなたの問題を再現することができ、メイン プロジェクトを実行しようとしたときにまったく同じ例外スタック トレースを取得できました。そのため、これが原因である可能性があると思います。
思った通り、これは Android メイン プロジェクトで Android ライブラリ プロジェクトを参照する方法、つまり単純な Eclipse 構成設定に関するものです。
間違ったやり方:
メイン プロジェクトを右クリックし、 を選択するとProperties -> Java Build Path -> Projects -> Add...
、Android ライブラリ プロジェクトが Android メイン プロジェクトのビルド パスに依存プロジェクトとして追加されますが、これは機能しません。必要なすべての Android 関連リソースがメイン プロジェクトで定義されている場合、コンパイル時にエラーは発生しませんが、アプリケーションを実行すると、質問に記載されている例外が発生します。
正しい方法:
メインプロジェクトを右クリックし、Properties -> Android
ライブラリセクションでAndroidライブラリプロジェクトを追加します。公式開発者ガイドを確認してください。ライブラリプロジェクトの参照これですべての問題が解決するはずです。また、実際のAndroidライブラリプロジェクトへの相対パス参照を使用する必要があることに注意してください。図書館プロジェクト - 開発に関する考慮事項。