2013-07-17 2 views
4

브로드 캐스트 리시버를 등록하여 패키지 할부 또는 제거 이벤트를 수신합니다.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의 업데이트가 아닙니다.

업데이트를 수행 할 때 안드로이드가 무엇을하는지 알고 싶습니다.

답변