パッケージのインストールまたはアンインストール イベントを受信するブロードキャスト レシーバーを登録します。
しかし、一部のユーザーは次のようなクラッシュ レポートを報告しています。
java.lang.RuntimeException: Unable to create application com.kc.security.MoSecurityApplication: java.lang.RuntimeException: getResources is null: dir - /data/app/com.cm.mg-1.apk, srcVal-1, srcVal-2
at android.app.LoadedApk.makeApplication(LoadedApk.java:495)
at android.app.ActivityThread.handleCreateService(ActivityThread.java:2249)
at android.app.ActivityThread.access$1600(ActivityThread.java:123)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1201)
at android.os.Handler.dispatchMessage(Handler.java:99)
at android.os.Looper.loop(Looper.java:137)
at android.app.ActivityThread.main(ActivityThread.java:4424)
at java.lang.reflect.Method.invokeNative(Native Method)
at java.lang.reflect.Method.invoke(Method.java:511)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:784)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:551)
at dalvik.system.NativeStart.main(Native Method)
Caused by: java.lang.RuntimeException: getResources is null: dir - /data/app/com.cm.mg-1.apk, srcVal-1, srcVal-2
at com.kc.security.b.ab.b(UpdateManager.java:69)
at com.kc.security.b.ab.a(UpdateManager.java:112)
at com.kc.security.MoSecurityApplication.onCreate(MoSecurityApplication.java:66)
at android.app.Instrumentation.callApplicationOnCreate(Instrumentation.java:969)
at android.app.LoadedApk.makeApplication(LoadedApk.java:492)
... 11 more
このクラッシュを再現するのは簡単ではありません。私たちはこの問題についてよく考えます。アンインストール イベントを受け取ると
、アプリケーション コンテキスト クラスがその onCreate メソッドを呼び出し、そこでいくつかの初期作業を行います。getResouce() を呼び出すと、null が返されます。フレームワーク コードの詳細を調べると、getReource が ApplicationInfo の sourceDir 文字列によってリソース ファイルを検索し、その文字列が "/data/app/com.cm.mg-1.apk" > 元の apk であることがわかります。もう存在しません。
ユーザーがアプリケーションを更新したときに発生する可能性があります。何らかの方法で「/data/app/com.cm.mg-1.apk」はすでに削除されており、「/data/app/com.cm.mg-2.apk」に置き換えられていますが、「sourceDir」文字列はApplicationInfo は更新されません。
更新を行うときにアンドロイドが何をするか知りたいです。