Androidマーケットでホストされているアプリケーションに取り組んでいます。ときどき (月に 1 回) クラッシュ レポートを受け取りました。
アプリケーション java.lang.ClassNotFoundException をインスタンス化できません
アプリのダウンロード数は 10,000 ~ 50,000 です。一部のデバイスでこの例外が発生する理由がわかりません(3つの異なるデバイスでテストしましたが、最後に再現できませんでした)。
この問題に関するさまざまな Android フォーラムの記事や提案を読みましたが、解決できませんでした。誰かが同様の問題に直面していて、どうすればよいか教えてくれますか?
注: このようにアプリケーションクラスを拡張しています
public class MyApplication extends Application {
}
このようにmanifest.xmlに登録します
<application android:icon="@drawable/app_icon"
android:label="@string/my_app_name" android:name="MyApplication">
スタックトレース :
java.lang.RuntimeException: Unable to instantiate application com.xyz.MyApplication java.lang.ClassNotFoundException: com.xyz.MyApplication in loader dalvik.system.PathClassLoader[/mnt/asec/com.xyz-1/pkg.apk]
at android.app.ActivityThread$PackageInfo.makeApplication(ActivityThread.java:650)
at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4238)
at android.app.ActivityThread.access$3000(ActivityThread.java:126)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:2076)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:123)
at android.app.ActivityThread.main(ActivityThread.java:4633)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:521)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:858)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.ClassNotFoundException: com.xyz.MyApplication in loader dalvik.system.PathClassLoader[/mnt/asec/com.xyz-1/pkg.apk]
at dalvik.system.PathClassLoader.findClass(PathClassLoader.java:243)
at java.lang.ClassLoader.loadClass(ClassLoader.java:573)
at java.lang.ClassLoader.loadClass(ClassLoader.java:532)
at android.app.Instrumentation.newApplication(Instrumentation.java:942)
at android.app.ActivityThread$PackageInfo.makeApplication(ActivityThread.java:645)
一部のデバイスでアプリケーションがクラッシュする理由はわかりません。