android.app.RemoteServiceException: at android.app.ActivityThread$H.handleMessage 在发送通知时

我使用服务来显示通知。在一些罕见的设备上(每天50 000个用户中有3个用户),我遇到了以下崩溃(可以在Google Play开发人员控制台中看到;仅在Android 4.x设备上):

android.app.RemoteServiceException: 
  at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1509)
  at android.os.Handler.dispatchMessage(Handler.java:110)
  at android.os.Looper.loop(Looper.java:193)
  at android.app.ActivityThread.main(ActivityThread.java:5327)
  at java.lang.reflect.Method.invokeNative(Native Method:0)
  at java.lang.reflect.Method.invoke(Method.java:515)
  at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:824)
  at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:640)
  at dalvik.system.NativeStart.main(Native Method:0)

我的通知是用这样的代码制作的(旧式通知,在Android 6 +中已弃用,但无论如何都有效;该错误在Android 4.x上,代码未被弃用):

Notification notification = new Notification(icon, "Custom Notification", when);
NotificationManager mNotificationManager = (NotificationManager) getSystemService(NOTIFICATION_SERVICE);
RemoteViews contentView = new RemoteViews(getPackageName(), R.layout.custom_notification);
contentView.setImageViewResource(R.id.notifWeatherImageView, WeatherRowTools.getImageForWeatherCode(weatherCodeString));

....some stuff here...

notification.contentView = contentView;
notification.contentIntent = contentIntent;
notification.flags |= Notification.FLAG_AUTO_CANCEL;
notification.defaults = 0;
mNotificationManager.notify(1, notification);

关于如何解决这个问题的任何想法?

多谢!!!


答案 1

我在我的构建中看到了类似的问题 - 只有Kitkat设备大量抛出这些问题 - Android操作系统版本:4.4.4,4.4.2,4.2.2,4.0.4

我们通过更改 通知 中使用的可绘制文件修复了类似的问题。

.addAction(R.drawable.ic_forward_black_24dp, VIEW_ACTION, pendingIntentView);

我们停止使用矢量资源,并开始使用图像资源。

R.drawable.ic_forward_black_24dp不再使用xml文件(矢量资源),而是使用png文件(图像资源)。


答案 2

检查一下。即使你使用的 SDK 与链接的答案不同,你的问题可能仍然有相同的原因。