1

皆さん、今晩は。

私は2つの異なるプロジェクトで使用するいくつかのクラスを持つ非Androidプロジェクトを持っています(1つはAndroidプロジェクトで、もう1つはそうではありません)。このプロジェクトから .jar ファイルをエクスポートして他のプロジェクトで使用しましたが、Android 以外のプロジェクトで動作します。Android プロジェクトでは、この .jar からクラスをインスタンス化しようとすると、NoClassDefFoundError が返されます。.jar を libs フォルダーに入れ、Order and Import タブで確認し、assets フォルダーにも入れてみましたが、どれも機能しませんでした。何が起こっているのか知っている人はいますか?Eclipse Kepler、Java 1.7 および Android 4.2.2 の使用

編集:

エラーを生成する行にブレークポイントを配置すると、logCat は次のように表示します。

08-15 09:32:08.970: E/dalvikvm(1051): Could not find class     'messageService.append.UserLoginAppend', referenced from method     gafit.activities.LoginActivity.attemptLogin
08-15 09:32:08.970: W/dalvikvm(1051): VFY: unable to resolve new-instance 1292 (LmessageService/append/UserLoginAppend;) in Lgafit/activities/LoginActivity;
08-15 09:32:08.970: D/dalvikvm(1051): VFY: replacing opcode 0x22 at 0x0009
08-15 09:32:08.970: D/dalvikvm(1051): VFY: dead code 0x000b-002f in Lgafit/activities/LoginActivity;.attemptLogin ()V

そして、ブレークポイントから再開した後:

08-15 09:35:17.660: E/AndroidRuntime(1051): FATAL EXCEPTION: main
08-15 09:35:17.660: E/AndroidRuntime(1051): java.lang.NoClassDefFoundError: messageService.Message
08-15 09:35:17.660: E/AndroidRuntime(1051):     at gafit.activities.LoginActivity.onCreate(LoginActivity.java:59)
08-15 09:35:17.660: E/AndroidRuntime(1051):     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1049)
08-15 09:35:17.660: E/AndroidRuntime(1051):     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:1611)
08-15 09:35:17.660: E/AndroidRuntime(1051):     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:1663)
08-15 09:35:17.660: E/AndroidRuntime(1051):     at android.app.ActivityThread.access$1500(ActivityThread.java:117)
08-15 09:35:17.660: E/AndroidRuntime(1051):     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:931)
08-15 09:35:17.660: E/AndroidRuntime(1051):     at android.os.Handler.dispatchMessage(Handler.java:99)
08-15 09:35:17.660: E/AndroidRuntime(1051):     at android.os.Looper.loop(Looper.java:130)
08-15 09:35:17.660: E/AndroidRuntime(1051):     at android.app.ActivityThread.main(ActivityThread.java:3683)
08-15 09:35:17.660: E/AndroidRuntime(1051):     at java.lang.reflect.Method.invokeNative(Native Method)
08-15 09:35:17.660: E/AndroidRuntime(1051):     at java.lang.reflect.Method.invoke(Method.java:507)
08-15 09:35:17.660: E/AndroidRuntime(1051):     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:880)
08-15 09:35:17.660: E/AndroidRuntime(1051):     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:638)
08-15 09:35:17.660: E/AndroidRuntime(1051):     at dalvik.system.NativeStart.main(Native Method)
08-15 09:35:17.660: E/AndroidRuntime(1051): Caused by: java.lang.ClassNotFoundException: messageService.Message in loader dalvik.system.PathClassLoader[/data/app/gafit.activities-1.apk]
08-15 09:35:17.660: E/AndroidRuntime(1051):     at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:240)
08-15 09:35:17.660: E/AndroidRuntime(1051):     at java.lang.ClassLoader.loadClass(ClassLoader.java:551)
08-15 09:35:17.660: E/AndroidRuntime(1051):     at java.lang.ClassLoader.loadClass(ClassLoader.java:511)
08-15 09:35:17.660: E/AndroidRuntime(1051):     ... 14 more
4

2 に答える 2

0

パッケージのインストール中に LogCat の出力を確認します。Dalvik が一部のクラスを拒否してロードしない場合があります。これに関する記録がログに表示されます。

ProGuard を使用すると、一部のクラスが欠落する可能性があります (たとえば、それらがリフレクションを介して使用されている場合)。

于 2013-08-15T03:10:46.277 に答える
0

何が間違っていたのかがわかりました。私の Android プロジェクトのコンプライアンス レベルは 1.6 に設定されており、.jar を生成したプロジェクトは 1.7 に設定されています。特に、このエラーが何も示されていないのは非常に奇妙に感じました...いずれにせよ、助けようとしたすべての人に感謝します!

于 2013-08-16T02:57:29.140 に答える