IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 移动开发 -> anr trace查看anr问题 -> 正文阅读

[移动开发]anr trace查看anr问题

当前项目的trace 线程阻塞的log如下

"Binder:685_1" prio=5 tid=9 Blocked
  | group="main" sCount=1 dsCount=0 flags=1 obj=0x147c0428 self=0xb400007650eb5e90
  | sysTid=701 nice=-10 cgrp=default sched=1073741824/0 handle=0x74cd662cc0
  | state=S schedstat=( 2834995063 648543473 13785 ) utm=211 stm=71 core=0 HZ=100
  | stack=0x74cd56b000-0x74cd56d000 stackSize=995KB
  | held mutexes=
  at com.android.server.am.ActivityManagerService.isUserAMonkey(ActivityManagerService.java:8714)
  - waiting to lock <0x06aed18c> (a com.android.server.am.ActivityManagerServiceEx) held by thread 14
  at android.app.ActivityManager.isUserAMonkey(ActivityManager.java:4183)
  at com.android.server.wm.RemoteAnimationController.onAnimationFinished(RemoteAnimationController.java:242)
  - locked <0x0a56a777> (a com.android.server.wm.WindowManagerGlobalLock)
  at com.android.server.wm.RemoteAnimationController.access$200(RemoteAnimationController.java:54)
  at com.android.server.wm.RemoteAnimationController$FinishedCallback.onAnimationFinished(RemoteAnimationController.java:333)
  at android.view.IRemoteAnimationFinishedCallback$Stub.onTransact(IRemoteAnimationFinishedCallback.java:85)
  at android.os.Binder.execTransactInternal(Binder.java:1159)
  at android.os.Binder.execTransact(Binder.java:1123)
"android.display" prio=5 tid=14 Blocked
  | group="main" sCount=1 dsCount=0 flags=1 obj=0x147c89d8 self=0xb400007650ec74b0
  | sysTid=763 nice=-3 cgrp=default sched=0/0 handle=0x7477666cc0
  | state=S schedstat=( 15759658538 1929287484 64065 ) utm=1145 stm=430 core=0 HZ=100
  | stack=0x7477563000-0x7477565000 stackSize=1043KB
  | held mutexes=
  at com.android.server.wm.WindowProcessController.hasActivitiesOrRecentTasks(WindowProcessController.java:654)
  - waiting to lock <0x0a56a777> (a com.android.server.wm.WindowManagerGlobalLock) held by thread 9
  at com.android.server.am.ProcessRecord.hasActivitiesOrRecentTasks(ProcessRecord.java:832)
  at com.android.server.am.ProcessList.updateLruProcessLocked(ProcessList.java:3353)
  at com.android.server.am.ProcessRecord.updateProcessInfo(ProcessRecord.java:1481)
  - locked <0x06aed18c> (a com.android.server.am.ActivityManagerServiceEx)
  at com.android.server.wm.-$$Lambda$BEx3OWenCvYAaV5h_J2ZkZXhEcY.accept(lambda:-1)
  at com.android.internal.util.function.pooled.PooledLambdaImpl.doInvoke(PooledLambdaImpl.java:307)
  at com.android.internal.util.function.pooled.PooledLambdaImpl.invoke(PooledLambdaImpl.java:201)
  at com.android.internal.util.function.pooled.OmniFunction.run(OmniFunction.java:97)
  at android.os.Handler.handleCallback(Handler.java:938)
  at android.os.Handler.dispatchMessage(Handler.java:99)
  at android.os.Looper.loop(Looper.java:223)
  at android.os.HandlerThread.run(HandlerThread.java:67)
  at com.android.server.ServiceThread.run(ServiceThread.java:44)

由以上信息得知

tid等锁
9com.android.server.wm.WindowManagerGlobalLockcom.android.server.am.ActivityManagerServiceEx
14com.android.server.am.ActivityManagerServiceExcom.android.server.wm.WindowManagerGlobalLock

分析得知,线程9等待线程14的AMS锁,导致死锁问题

解决办法:将线程9的同步锁改为非同步锁

根据log得知该方法在同步锁的时候出现死锁com.android.server.am.ActivityManagerService.isUserAMonkey

改为非同步锁即可,展锐提供的的方法

diff --git a/services/core/java/com/android/server/wm/RemoteAnimationController.java b/services/core/java/com/android/server/wm/RemoteAnimationController.java index c682441..a5ef649 100644 --- a/services/core/java/com/android/server/wm/RemoteAnimationController.java +++ b/services/core/java/com/android/server/wm/RemoteAnimationController.java @@ -239,7 +239,7 @@ try { mPendingAnimations.remove(i); } catch (IndexOutOfBoundsException iobe) { - if (ActivityManager.isUserAMonkey()){ + if (mService.mAmInternal != null && mService.mAmInternal.isUserAMonkeyNoCheck()){ (20210806T07:09:17)

参考链接

https://blog.csdn.net/c_z_w/article/details/89021647

https://blog.csdn.net/wd229047557/article/details/108059436?utm_medium=distribute.pc_relevant.none-task-blog-2%7Edefault%7EOPENSEARCH%7Edefault-1.control&depth_1-utm_source=distribute.pc_relevant.none-task-blog-2%7Edefault%7EOPENSEARCH%7Edefault-1.control

  移动开发 最新文章
Vue3装载axios和element-ui
android adb cmd
【xcode】Xcode常用快捷键与技巧
Android开发中的线程池使用
Java 和 Android 的 Base64
Android 测试文字编码格式
微信小程序支付
安卓权限记录
知乎之自动养号
【Android Jetpack】DataStore
上一篇文章      下一篇文章      查看所有文章
加:2021-08-10 13:32:03  更:2021-08-10 13:33:22 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/18 23:34:39-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码