高通项目 首次开机后apk随机报错

在msm8909项目开发中遇到问题,设备首次开机时部分apk出现错误,表现为类找不到。通过Log分析,问题源于开机时的dexopt优化线程在apk依赖的开机广播启动之前进行,导致部分apk无法找到class。解决方案是移除高通添加的apk缓存链表代码,直接进行dexopt。此问题可能是为了提高首次开机速度而引入的,但也引发了冲突。
摘要由CSDN通过智能技术生成

     在开发msm8909项目过程中,碰到一个现象,就是烧完版本后开机,会随机出现apk报错的情况,过一段时间,再关机开机,就没有报错。

     在Log中,主要报如下错误:


E AndroidRuntime: java.lang.RuntimeException: Unable to get provider com.android.providers.contacts.debug.DumpFileProvider: java.lang.ClassNotFoundException: Didn't find class "com.android.providers.contacts.debug.DumpFileProvider" on path: DexPathList[[zip file "/system/priv-app/ContactsProvider/ContactsProvider.apk"],nativeLibraryDirectories=[/vendor/lib, /system/lib]]
E AndroidRuntime: at android.app.ActivityThread.installProvider(ActivityThread.java:5002)
E AndroidRuntime: at android.app.ActivityThread.installContentProviders(ActivityThread.java:4594)
E AndroidRuntime: at android.app.ActivityThread.handleBindApplication(ActivityThread.java:4534)
E AndroidRuntime: at android.app.ActivityThread.access$1500(ActivityThread.java:151)
E AndroidRuntime: at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1364)
E AndroidRuntime: at android.os.Handler.dispatchMessage(Handler.java:102)
E AndroidRuntime: at android.os.Looper.loop(Looper.jav

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值