Android-java.lang.RuntimeException: Package manager has died问题
发布日期:2021-10-04 02:53:24
浏览次数:5
分类:技术文章
本文共 1916 字,大约阅读时间需要 6 分钟。
记录下今天遇到的一个bug。
异常Log:CustomerExceptionHandler:pool-8-thread-5java.lang.RuntimeException: Package manager has diedE/hp (13562): at android.app.ApplicationPackageManager.getInstalledPackages(ApplicationPackageManager.java:464)E/hp (13562): at android.app.ApplicationPackageManager.getInstalledPackages(ApplicationPackageManager.java:454)E/hp (13562): at com.handpay.zztong.hp.utils.Util.getAppInstalled(Util.java:34)E/hp (13562): at com.handpay.zztong.hp.NewMainActivity1$1.run(NewMainActivity1.java:134)E/hp (13562): at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1080)E/hp (13562): at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:573)E/hp (13562): at java.lang.Thread.run(Thread.java:841)E/hp (13562): Caused by: android.os.TransactionTooLargeExceptionE/hp (13562): at android.os.BinderProxy.transact(Native Method)E/hp (13562): at android.content.pm.IPackageManager$Stub$Proxy.getInstalledPackages(IPackageManager.java:2528)E/hp (13562): at android.app.ApplicationPackageManager.getInstalledPackages(ApplicationPackageManager.java:461)
在activity中有线程去获取手机安装的app应用,结果在某些手机上退出重新进入会出现 Package manager has died错误。
原因:Binder调用出错了,看其源码(frameworks/base/core/jni/android_util_Binder.cpp)应该可以得知 如果Binder的使用超出了一个进程的限制就会抛出TransactionTooLargeException这个异常。如果是其他原因造成Binder crash的话就会抛出RuntimeException。从frameworks/native/libs/binder/ProcessState.cpp中得知一个进程的Binder的内存限制为(大约1M)
#define BINDER_VM_SIZE ((1*1024*1024) - (4096 *2))
解决方案:
executorService.execute(new Runnable() { @Override public void run() { // TODO Auto-generated method stub synchronized(NewMainActivity1.class) { Listpks = Util.getAppInstalled(NewMainActivity1.this); } } });
在调用前加synchronized同步锁 避免多个线程同时来调用Binder导致crash。
转载地址:https://blog.csdn.net/leifengpeng/article/details/52775938 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
做的很好,不错不错
[***.243.131.199]2024年04月15日 19时25分48秒
关于作者
喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
歪门邪道
2019-04-26
我的前六年程序生涯
2019-04-26
知识地图
2019-04-26
罗马总会建成
2019-04-26
程序通过技术赚钱的八个途径
2019-04-26
我在爬坡阶段
2019-04-26
大疆机甲大师教育机器人Python开发:中文命名变量初尝试
2019-04-26
大疆机甲大师教育机器人Python开发:API中文化初尝试
2019-04-26
大疆机甲大师Python开发: 两只老虎
2019-04-26
大疆机甲大师教育机器人Python API中文化之一:枪亮枪暗
2019-04-26
大疆机甲大师教育机器人Python API中文化之二:LED闪烁
2019-04-26
大疆 RoboMaster 机甲大师官方刚刚开通”机甲小 S 实验室”知乎专栏
2019-04-26
大疆机甲大师教育机器人Python API中文化之三:底盘灯效
2019-04-26
大疆机甲大师教育机器人Python API中文化之四五:云台灯效,指定序号
2019-04-26
大疆机甲大师教育机器人Python API中文化之六:关灯
2019-04-26
“中文编程”知乎专栏两岁了——山雨欲来风满楼
2019-04-26
大疆机甲大师Python API之七:做个闹钟
2019-04-26
【意外走向】大疆机甲大师Python API之八:计时——为性能测试展开1000次循环
2019-04-26