当前位置: 首页 > news >正文

Android性能优化之游戏引擎初始化ANR

近期,着手对bugly上的anr 处理,记录下优化的方向。

借用网上的一张图:
在这里插入图片描述

这里的anr 问题是属于主线程的call 耗时操作。需要使用trace 来获取发生anr前一些列的耗时方法调用时间,再次梳理业务,才可能解决。

问题1
java 调用栈:
在这里插入图片描述
从调用栈中发现onActivityResult()执行对游戏侧的初始化会造成anr。

因靠打印是不准确,存在多线程抢占cpu的缘故,因此考虑通过获取trace来记录方法的真正执行时间。

记录oppo渠道包的冷启动到登录页面的sample trace文件,总览trace中存在的耗时点:这里查看主线程中执行方法。
在这里插入图片描述
淡绿色是app中的代码,长方形占用面积越大,越耗时。

查看onActvityResult的逻辑执行时间:
在这里插入图片描述
发现Show_GLView()执行耗时最多,其中NativeInit()函数中调用若干方法,游戏C++层初始化了一大堆的逻辑。

问题2

anr发生的调用栈
在这里插入图片描述
通过调用栈oppo渠道中发现onResume执行对渠道初始化发生anr。

通过trace,来看下onResume中执行时间:
在这里插入图片描述
发现,onResume中初始化聚合渠道任务初始化,耗时100多毫秒。该任务可能并不是真正引起anr的真凶,可能是onActivityResult()耗时过多,间接导致onResume()过程中被系统判定anr。

方案优化

耗时任务的解决有三种方式:

  • 将耗时任务放到异步线程中执行
  • 将耗时任务 lazy延后策略执行或者 提前选择空闲时间执行。

当界面1 跳转其他界面2后,当界面2调用finish()销毁时:

先执行界面2的onStop()–>界面1的onActivityResult()->界面1的onResume()–>界面2的onstop()–>界面2的onDestroy()。

尝试将nativeInit()和Show_GLView_Two() 放到onActvivityResult()和onResume()之后执行。为了不阻塞onResume()执行,利用hanlde的空闲机制:
在这里插入图片描述
在onActivityResult之后执行空闲任务:
在这里插入图片描述
Onresume 之后添加延迟任务:
在这里插入图片描述
按照以上调整逻辑,再次编译渠道包,来看下优化效果

优化效果

查看onActivityResult()中onResume()执行时间:

在这里插入图片描述
同时也反馈给游戏侧c++层的同事,初始化根据业务,进行延迟、异步等操作细分调用时间。

资料借鉴:

  • https://www.zhihu.com/tardis/bd/art/552305686?source_id=1001
http://www.lryc.cn/news/100649.html

相关文章:

  • Jmap-JVM(十六)
  • 【分布式能源的选址与定容】基于多目标粒子群算法分布式电源选址定容规划研究(Matlab代码实现)
  • flink源码分析-获取JVM最大堆内存
  • 第17节 R语言分析:生物统计数据集 R 编码分析和绘图
  • 一文了解什么是Selenium自动化测试?
  • java接口实现
  • 数据结构入门指南:链表(新手避坑指南)
  • SpringBoot第24讲:SpringBoot集成MySQL - MyBatis XML方式
  • linux 查看网卡,网络情况
  • 在Mac上搭建Gradle环境
  • Docker网络与Docker Compose服务编排
  • opencv+ffmpeg环境(ubuntu)搭建全面详解
  • 开发基于 LoRaWAN 的设备须知--最大兼容性
  • 一、SpringBoot基础[日志]
  • libuv库学习笔记-networking
  • C++多线程编程(第三章 案例1,使用互斥锁+ list模拟线程通信)
  • IOS UICollectionView 设置cell大小不生效问题
  • 浅谈3D隐式表示(SDF,Occupancy field,NeRF)
  • 软件测试技能大赛任务二单元测试试题
  • MybatisPlus拓展篇
  • 设置k8s中节点node的ROLES值,K8S集群怎么修改node1的集群ROLES
  • 【*1900 图论】CF1328 E
  • 微信开发者工具 miniprogram_npm 未找到
  • 计算机视觉(三)未有深度学习之前
  • 二十六、媒体查询2
  • Themis 国库建设计划启动,开启去中心化新征程
  • uni-app:模态框的实现(弹窗实现)
  • 第九章:stack类
  • FSM:Full Surround Monodepth from Multiple Cameras
  • idea 安装 插件jrebel 报错LS client not configured.