Systrace分析游戏卡顿问题之王者荣耀CPU资源不足

2024-01-21 19:50

本文主要是介绍Systrace分析游戏卡顿问题之王者荣耀CPU资源不足,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

写在最前

在2018年以前,王者荣耀这款游戏对手机性能的需求很高,只有少数旗舰处理器才能流畅60帧运行,主要原因是游戏本身绝大部分任务集中在一个叫UnityMain的线程中,这个重负载的线程常常会因为CPU没办法满足其性能需求,导致一帧的处理时间超出16ms,进而表现出帧率波动/掉帧。
2018年开始游戏方普及了多线程版本,也就是把原来的一个UnityMain拆分成了两个线程,对于CPU的最大性能需求降低了,在同平台上性能表现当然更好,更稳定

本文的目的是从systrace的角度,来呈现不同的CPU资源(频率)对于游戏帧率的影响,首先是要创造对比测试条件

创造条件
  • 游戏设置 - 王者荣耀
    • 高帧率
    • 单人训练
  • 对比条件
    • 关闭大核
    • 小核1.7GHz VS 小核 825MHz
systrace 分析
1. CPU频率

可以看到8423时间点CPU频率从1.7GHz下降到了825MHz
在这里插入图片描述

2. 游戏帧率

在频率下降之前,游戏帧率大概是50-55fps之间,频率下降到825MHz之后,FPS降低到了40以下

UnityGfxDeviceW线程应该就是负责渲染的
首先通过dequeueBuffer拿到buffer,然后绘制渲染,完成之后调用queueBuffer通知SF这个buffer可以交到屏幕上去显示,这样就完成了一帧
在这里插入图片描述

下图的红栅格线是16.7ms一格,可以看到在8420ms前后,UnityGfxDeviceW完成一帧的时间差距明显
在这里插入图片描述

3. CPU性能影响
  • 首先这是一个很单纯的场景,负载基本一致,没有太大波动
    所以从上面的systrace就可以确认是CPU的性能影响导致,拿50fps以上和30fps左右的UnityGfxDeviceW来对比
  • 可以看到主要部分的时间从11.3ms变成了19.7ms,而且这个期间进程都基本处于running状态
  • 进程所处的CPU性能是一致的

图1 1.7GHz
在这里插入图片描述
图2 825MHz
在这里插入图片描述

所以可以通过绘制一帧UnityGfxDeviceW线程的running时间来确认,这个是由于CPU性能不足导致的掉帧

这篇关于Systrace分析游戏卡顿问题之王者荣耀CPU资源不足的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/630648

相关文章

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

如何解决idea的Module:‘:app‘platform‘android-32‘not found.问题

《如何解决idea的Module:‘:app‘platform‘android-32‘notfound.问题》:本文主要介绍如何解决idea的Module:‘:app‘platform‘andr... 目录idea的Module:‘:app‘pwww.chinasem.cnlatform‘android-32

kali linux 无法登录root的问题及解决方法

《kalilinux无法登录root的问题及解决方法》:本文主要介绍kalilinux无法登录root的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录kali linux 无法登录root1、问题描述1.1、本地登录root1.2、ssh远程登录root2、

SpringBoot应用中出现的Full GC问题的场景与解决

《SpringBoot应用中出现的FullGC问题的场景与解决》这篇文章主要为大家详细介绍了SpringBoot应用中出现的FullGC问题的场景与解决方法,文中的示例代码讲解详细,感兴趣的小伙伴可... 目录Full GC的原理与触发条件原理触发条件对Spring Boot应用的影响示例代码优化建议结论F

MySQL 中查询 VARCHAR 类型 JSON 数据的问题记录

《MySQL中查询VARCHAR类型JSON数据的问题记录》在数据库设计中,有时我们会将JSON数据存储在VARCHAR或TEXT类型字段中,本文将详细介绍如何在MySQL中有效查询存储为V... 目录一、问题背景二、mysql jsON 函数2.1 常用 JSON 函数三、查询示例3.1 基本查询3.2

Python 迭代器和生成器概念及场景分析

《Python迭代器和生成器概念及场景分析》yield是Python中实现惰性计算和协程的核心工具,结合send()、throw()、close()等方法,能够构建高效、灵活的数据流和控制流模型,这... 目录迭代器的介绍自定义迭代器省略的迭代器生产器的介绍yield的普通用法yield的高级用法yidle

Pyserial设置缓冲区大小失败的问题解决

《Pyserial设置缓冲区大小失败的问题解决》本文主要介绍了Pyserial设置缓冲区大小失败的问题解决,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 目录问题描述原因分析解决方案问题描述使用set_buffer_size()设置缓冲区大小后,buf

resultMap如何处理复杂映射问题

《resultMap如何处理复杂映射问题》:本文主要介绍resultMap如何处理复杂映射问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录resultMap复杂映射问题Ⅰ 多对一查询:学生——老师Ⅱ 一对多查询:老师——学生总结resultMap复杂映射问题

java实现延迟/超时/定时问题

《java实现延迟/超时/定时问题》:本文主要介绍java实现延迟/超时/定时问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java实现延迟/超时/定时java 每间隔5秒执行一次,一共执行5次然后结束scheduleAtFixedRate 和 schedu

C++ Sort函数使用场景分析

《C++Sort函数使用场景分析》sort函数是algorithm库下的一个函数,sort函数是不稳定的,即大小相同的元素在排序后相对顺序可能发生改变,如果某些场景需要保持相同元素间的相对顺序,可使... 目录C++ Sort函数详解一、sort函数调用的两种方式二、sort函数使用场景三、sort函数排序