getResources返回null

时间:2013-07-17 06:42:35

标签: java android

我们注册广播接收器以接收包安装或卸载事件。

但有些用户报告崩溃报告如下:

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定位资源文件   ApplicationInfo中的字符串,字符串为“/data/app/com.cm.mg-1.apk”>它是原始的apk,它不再存在。

当用户更新我们的应用程序时可能会发生。在某种程度上“/data/app/com.cm.mg-1.apk”已经全部删除并以“/data/app/com.cm.mg-2.apk”替换,但是“sourceDir”字符串在ApplicationInfo中没有更新。

  

我想知道android在进行更新时会做什么。

1 个答案:

答案 0 :(得分:1)

遇到类似的问题,请查看。

RuntimeException: Unable to instantiate application

我认为这应该回答这个问题,可能是因为在此卸载事件期间资源已被销毁。

相关问题