WaitForGcToComplete 因 DisableMovingGc 而阻塞 89.851 毫秒
WaitForGcToComplete blocked for 89.851ms for cause DisableMovingGc
我有两个版本的应用程序,付费版和免费版。两个版本共享相同的通知服务代码。一个版本正在工作,另一个版本似乎通过代码 运行 并启动显示警报的方法,但这永远不会显示给用户,而是我在 logcat:
中得到它
20:23:51.926 I/art: WaitForGcToComplete blocked for 5.737ms for cause DisableMovingGc
04-20 20:23:54.531 I/art: Thread[5,tid=12452,WaitingInMainSignalCatcherLoop,Thread*=0xb7e9eec0,peer=0x32c0a0a0,"Signal Catcher"]: reacting to signal 3
04-20 20:23:54.755 I/art: Wrote stack traces to '/data/anr/traces.txt'
应用程序的其他方面有很多差异,但最近增加的一项是混合面板跟踪,我过去曾看到它与垃圾收集问题有关。这在两个应用程序中都存在,但每个应用程序中的跟踪不同。
我查看了 traces.txt 文件,但老实说它很大,我不确定我在找什么。我发现了类似的东西,但没有帮助:
"ActivityManager" prio=5 tid=16 TimedWaiting
| group="main" sCount=1 dsCount=0 obj=0x12d4c9e0 self=0xb7e73020
| sysTid=579 nice=-2 cgrp=default sched=0/0 handle=0xb7e73628
| state=S schedstat=( 0 0 0 ) utm=2110 stm=2446 core=1 HZ=100
| stack=0xa396a000-0xa396c000 stackSize=1036KB
| held mutexes=
at java.lang.Object.wait!(Native method)
- waiting on <0x1b396375> (a com.android.server.am.ActivityManagerService)
at java.lang.Object.wait(Object.java:422)
at com.android.server.am.ActivityManagerService.dumpStackTraces(ActivityManagerService.java:4800)
- locked <0x1b396375> (a com.android.server.am.ActivityManagerService)
at com.android.server.am.ActivityManagerService.dumpStackTraces(ActivityManagerService.java:4777)
at com.android.server.am.ActivityManagerService.appNotResponding(ActivityManagerService.java:5018)
at com.android.server.am.BroadcastQueue$AppNotResponding.run(BroadcastQueue.java:171)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:135)
at android.os.HandlerThread.run(HandlerThread.java:61)
at com.android.server.ServiceThread.run(ServiceThread.java:46)
我该如何调试它?
编辑
代替知道如何调试我只是破解并注释掉下面的代码允许服务保持 运行ning 所以它在这里导致 Gc 错误但是为什么,它与另一个相同有效的应用程序?
void sendNotification(String message) {
Log.e(TAG, "send notification");
/*NotificationCompat.Builder mBuilder =
(NotificationCompat.Builder) new NotificationCompat.Builder(this)
.setSmallIcon(R.drawable.ic_notification_icon)
.setContentTitle(message)
.setContentText("since you last serviced your shocks")
.setColor(0xffCDDC39)
.setAutoCancel(true);
Intent resultIntent = new Intent(this, ActivitiesActivity.class);
TaskStackBuilder stackBuilder = TaskStackBuilder.create(this);
stackBuilder.addParentStack(ActivitiesActivity.class);
stackBuilder.addNextIntent(resultIntent);
PendingIntent resultPendingIntent =
stackBuilder.getPendingIntent(
0,
PendingIntent.FLAG_UPDATE_CURRENT
);
mBuilder.setContentIntent(resultPendingIntent);
NotificationManager mNotificationManager =
(NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
mNotificationManager.notify(mId, mBuilder.build());*/
}
发现错误。这是一个相当愚蠢的错误。
原来你的 android:parentActivityName=
等于 activity 名称(复制并粘贴拼写错误)它会导致各种垃圾收集错误,除非你尝试发送,否则你可能不会注意到通知。谁知道?
我有两个版本的应用程序,付费版和免费版。两个版本共享相同的通知服务代码。一个版本正在工作,另一个版本似乎通过代码 运行 并启动显示警报的方法,但这永远不会显示给用户,而是我在 logcat:
中得到它20:23:51.926 I/art: WaitForGcToComplete blocked for 5.737ms for cause DisableMovingGc
04-20 20:23:54.531 I/art: Thread[5,tid=12452,WaitingInMainSignalCatcherLoop,Thread*=0xb7e9eec0,peer=0x32c0a0a0,"Signal Catcher"]: reacting to signal 3
04-20 20:23:54.755 I/art: Wrote stack traces to '/data/anr/traces.txt'
应用程序的其他方面有很多差异,但最近增加的一项是混合面板跟踪,我过去曾看到它与垃圾收集问题有关。这在两个应用程序中都存在,但每个应用程序中的跟踪不同。
我查看了 traces.txt 文件,但老实说它很大,我不确定我在找什么。我发现了类似的东西,但没有帮助:
"ActivityManager" prio=5 tid=16 TimedWaiting
| group="main" sCount=1 dsCount=0 obj=0x12d4c9e0 self=0xb7e73020
| sysTid=579 nice=-2 cgrp=default sched=0/0 handle=0xb7e73628
| state=S schedstat=( 0 0 0 ) utm=2110 stm=2446 core=1 HZ=100
| stack=0xa396a000-0xa396c000 stackSize=1036KB
| held mutexes=
at java.lang.Object.wait!(Native method)
- waiting on <0x1b396375> (a com.android.server.am.ActivityManagerService)
at java.lang.Object.wait(Object.java:422)
at com.android.server.am.ActivityManagerService.dumpStackTraces(ActivityManagerService.java:4800)
- locked <0x1b396375> (a com.android.server.am.ActivityManagerService)
at com.android.server.am.ActivityManagerService.dumpStackTraces(ActivityManagerService.java:4777)
at com.android.server.am.ActivityManagerService.appNotResponding(ActivityManagerService.java:5018)
at com.android.server.am.BroadcastQueue$AppNotResponding.run(BroadcastQueue.java:171)
at android.os.Handler.handleCallback(Handler.java:739)
at android.os.Handler.dispatchMessage(Handler.java:95)
at android.os.Looper.loop(Looper.java:135)
at android.os.HandlerThread.run(HandlerThread.java:61)
at com.android.server.ServiceThread.run(ServiceThread.java:46)
我该如何调试它?
编辑
代替知道如何调试我只是破解并注释掉下面的代码允许服务保持 运行ning 所以它在这里导致 Gc 错误但是为什么,它与另一个相同有效的应用程序?
void sendNotification(String message) {
Log.e(TAG, "send notification");
/*NotificationCompat.Builder mBuilder =
(NotificationCompat.Builder) new NotificationCompat.Builder(this)
.setSmallIcon(R.drawable.ic_notification_icon)
.setContentTitle(message)
.setContentText("since you last serviced your shocks")
.setColor(0xffCDDC39)
.setAutoCancel(true);
Intent resultIntent = new Intent(this, ActivitiesActivity.class);
TaskStackBuilder stackBuilder = TaskStackBuilder.create(this);
stackBuilder.addParentStack(ActivitiesActivity.class);
stackBuilder.addNextIntent(resultIntent);
PendingIntent resultPendingIntent =
stackBuilder.getPendingIntent(
0,
PendingIntent.FLAG_UPDATE_CURRENT
);
mBuilder.setContentIntent(resultPendingIntent);
NotificationManager mNotificationManager =
(NotificationManager) getSystemService(Context.NOTIFICATION_SERVICE);
mNotificationManager.notify(mId, mBuilder.build());*/
}
发现错误。这是一个相当愚蠢的错误。
原来你的 android:parentActivityName=
等于 activity 名称(复制并粘贴拼写错误)它会导致各种垃圾收集错误,除非你尝试发送,否则你可能不会注意到通知。谁知道?