13

我收到一个安装了很多应用程序的用户的邮件,当我的应用程序使用以下代码收集活动信息时,他遇到了问题:

getPackageManager().queryIntentActivities(mAinIntent, 0)

整个来源:https ://github.com/ligi/FAST

这就是发生的事情

Caused by: java.lang.RuntimeException: Package manager has died
at android.app.ApplicationPackageManager.queryIntentActivities(ApplicationPackageManager.java:479)
at org.ligi.fast.BaseAppGatherAsyncTask.doInBackground(BaseAppGatherAsyncTask.java:34)
at org.ligi.fast.BaseAppGatherAsyncTask.doInBackground(BaseAppGatherAsyncTask.java:1)
at android.os.AsyncTask$2.call(AsyncTask.java:287)
at java.util.concurrent.FutureTask$Sync.innerRun(FutureTask.java:305)
... 5 more
Caused by: android.os.TransactionTooLargeExceptionTransactionTooLargeException
at android.os.BinderProxy.transact(Native Method)
at android.content.pm.IPackageManager$Stub$Proxy.queryIntentActivities(IPackageManager.java:2230)
at android.app.ApplicationPackageManager.queryIntentActivities(ApplicationPackageManager.java:473)
... 9 more
Log:
0 D: Writing unhandled exception to: /data/data/org.ligi.fast/files/3.7-1364933885194.tracedroid

似乎有一个问题,我在 1mb 边界上运行,但是如何离开那里?我还能如何获得所需的信息?有没有办法将数据分块?

4

1 回答 1

7

不久前,我在使用相同的用户输入时遇到了这个错误。虽然我抛出的事件不同。我最终捕获了异常并优雅地向用户报告安装了太多具有处理能力的应用程序。在数十万次安装中,我只在一个项目中看到这个错误不到五次,我知道这不是借口,但有些设备只是没有堆来处理索引每个已安装应用程序的意图在设备上。

于 2014-12-11T20:13:41.870 回答