브로드 캐스트 리시버를 등록하여 패키지 할부 또는 제거 이벤트를 수신합니다.getResources returns null
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가 sourceDir에 의해 리소스 파일을 찾습니다. String은 ApplicationInfo에 있으며 문자열은 "/data/app/com.cm.mg-1.apk"> 원래 apk이며 더 이상 존재하지 않습니다.
사용자가 애플리케이션을 업데이트 할 때 발생할 수 있습니다. 어떤면에서는 "/data/app/com.cm.mg-1.apk"이 모두 삭제되어 "/data/app/com.cm.mg-2.apk"로 바뀌지 만 "sourceDir"String ApplicationInfo의 업데이트가 아닙니다.
업데이트를 수행 할 때 안드로이드가 무엇을하는지 알고 싶습니다.