リリース 17 への最新の ADT アップデート以降、厄介な問題が発生しているようです。
問題を説明するために簡単なアプリケーションを作成しましたが、何か間違っているかどうかわかりません。私のアプリケーションのメイン アクティビティは、サポート パッケージの FragmentActivity から継承していますが、何らかの理由でアプリケーションが起動時にクラッシュします。
説明のために、サンプル プロジェクトを作成しました。
まず、ダミー クラス DummyProjectActivity のコードは非常に単純です。
public class DummyProjectActivity extends FragmentActivity {
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
}
}
次に、マニフェストがあります。
<?xml version="1.0" encoding="utf-8"?>
<manifest xmlns:android="http://schemas.android.com/apk/res/android"
package="be.emich.labs"
android:versionCode="1"
android:versionName="1.0" >
<uses-sdk android:minSdkVersion="8" />
<application
android:icon="@drawable/ic_launcher"
android:label="@string/app_name" >
<activity
android:name=".DummyProjectActivity"
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>
.jar ファイルがプロジェクトに正しくインポートされ、次のスタック トレースが表示されます。
E/AndroidRuntime(11509): FATAL EXCEPTION: main
E/AndroidRuntime(11509): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{be.emich.labs/be.emich.labs.DummyProjectActivity}: java.lang.ClassNotFoundException: be.emich.labs.DummyProjectActivity
E/AndroidRuntime(11509): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1879)
E/AndroidRuntime(11509): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1980)
E/AndroidRuntime(11509): at android.app.ActivityThread.access$600(ActivityThread.java:122)
E/AndroidRuntime(11509): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1146)
E/AndroidRuntime(11509): at android.os.Handler.dispatchMessage(Handler.java:99)
E/AndroidRuntime(11509): at android.os.Looper.loop(Looper.java:137)
E/AndroidRuntime(11509): at android.app.ActivityThread.main(ActivityThread.java:4340)
E/AndroidRuntime(11509): at java.lang.reflect.Method.invokeNative(Native Method)
E/AndroidRuntime(11509): at java.lang.reflect.Method.invoke(Method.java:511)
E/AndroidRuntime(11509): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
E/AndroidRuntime(11509): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
E/AndroidRuntime(11509): at dalvik.system.NativeStart.main(Native Method)
E/AndroidRuntime(11509): Caused by: java.lang.ClassNotFoundException: be.emich.labs.DummyProjectActivity
E/AndroidRuntime(11509): at dalvik.system.BaseDexClassLoader.findClass(BaseDexClassLoader.java:61)
E/AndroidRuntime(11509): at java.lang.ClassLoader.loadClass(ClassLoader.java:501)
E/AndroidRuntime(11509): at java.lang.ClassLoader.loadClass(ClassLoader.java:461)
E/AndroidRuntime(11509): at android.app.Instrumentation.newActivity(Instrumentation.java:1023)
E/AndroidRuntime(11509): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1870)
E/AndroidRuntime(11509): ... 11 more
ここで何が間違っていますか?これは最新の開発ツールのバグでしょうか?
互換性ライブラリの FragmentActivity を使用するすべてのプロジェクトで問題が発生しています。何が間違っているのかわかりません。他にこの問題を抱えている人はいますか?助けていただければ幸いです。FragmentActivity から継承する Activity に問題はありません。アプリケーションをアンインストール/再インストールしました。様々な「クリーンプロジェクト」を実施。エクリプスを再起動しました。
更新: この問題は明らかに互換性パッケージに関連しているのではなく、ADT r17 が jar ファイルのリンクを処理する方法に関連しています。含まれる Jar は libs/ フォルダーに配置する必要があり、ADT はそれらを自動的にリンクします。そうしないと、APK から欠落し、jarfile のコードが呼び出されるたびにアプリがクラッシュします。