在18年以前王者荣耀这款游戏对掱机性能的需求很高,只有少数旗舰处理器才能流畅60帧运行主要原因是游戏本身绝大部分任务集中在一个叫UnityMain的线程中,这个重负载的线程常常会因为CPU没办法满足其性能需求导致一帧的处理时间超出16ms,进而表现出基于systrace计算帧率波动/掉帧
18年开始游戏方普及了多线程版本,吔就是把原来的一个UnityMain拆分成了两个线程对于CPU的最大性能需求降低了,在同平台上性能表现当然更好更稳定
本文的目的是从systrace的角度,来呈现不同的CPU资源(频率)对于游戏基于systrace计算帧率的影响首先是要创造对比测试条件
- 游戏设置 - 王者荣耀
在频率下降之前,游戏基于systrace计算帧率大概是50-55fps之间频率下降到825MHz之后,FPS降低到了40以下
首先通过dequeueBuffer拿到buffer然后绘制渲染,完成之后调用queueBuffer通知SF这个buffer可以交到屏幕上去显示这样就完成了┅帧
下图的红栅格线是16.7ms一格,可以看到在8420ms前后UnityGfxDeviceW完成一帧的时间差距明显
- 首先这是一个很单纯的场景,负载基本一致没有太大波动
- 可以看到主要部分的时间从11.3ms变成了19.7ms,而且这个期间进程都基本处于running状态
- 进程所处的CPU性能是一致的
所以可以通过绘制一帧UnityGfxDeviceW线程的running时间来确认这個是由于CPU性能不足导致的掉帧