zoukankan      html  css  js  c++  java
  • 游戏性能指标

    对不同主流机器(一般来自TOP20配置,覆盖90%以上的设备)根据不同硬件能力建立高、中、低等多档性能指标,游戏按照该指标对应多个画质选项进行适配。

    CPU负载:一帧内执行的指令数

    GPU负载:一帧内执行的shader指令数

    FPS:游戏每秒运行的帧数

    ① GPU瓶颈

    影响因素有:DrawCall数、shader复杂度、纹理采样、透明物件、OverDraw、RenderState频繁切换

    使用GPA等进行截帧分析

    ② CPU瓶颈

    影响因素有:游戏逻辑、剔除算法、Cache Missing

    使用VTune等进行函数耗时分析

    ③ 传输瓶颈

    影响因素有:VBO(Vertex Buffer Object)顶点数据量

    卡顿:发生瞬间掉帧的次数

    内存:包括虚拟内存和物理内存

    ① 虚拟内存

    Private Bytes  // 进程Committed的虚拟内存字节数    对应win7任务管理器中的【提交大小】,资源管理器中的【提交】

    Peak Private Bytes  // 进程Committed的虚拟内存的最高峰字节数

    Virtual Size // 进程Reserved的虚拟地址空间字节数

    Page Faults  // 发生过的缺页中断次数    对应win7任务管理器中的【页面错误】

    虚拟内存地址空间碎片  // 不可用的虚拟内存空间,造成的原因有:

                                    a. windows保留虚拟地址空间起始地址必须是系统分配粒度的整数倍(64KB),大小必须是系统页面大小的整数倍(4KB)

                                    b. windows提交虚拟地址空间起始地址和大小必须是系统页面大小的整数倍(4KB)

    ② 物理内存

    Working Set = WS Private + WS Shareable  // 进程占用物理内存总字节数  对应win7任务管理器中的【工作设置(内存)】,资源管理器中的【工作集】

         WS Private // 进程独享的物理内存字节数(如:堆内存+栈内存+cow机制创建的内存)   对应win7任务管理器中的【内存(专用工作集)】,资源管理器中的【专用】

         WS Shareable  // 进程可与其他进程共享的物理内存字节数(如:exe及dll代码段、数据段等)  对应win7资源管理器中的【可共享】

         WS Shared  // 进程已与其他进程共享的物理内存字节数,WS Shared<=WS Shareable

                             // 若只启动一个exe实例,那么exe的代码段、数据段等不会被共享,因而就不统计在WS Shared中

    Peak Working Set // 物理内存的最高峰字节数  对应win7任务管理器中的【峰值工作设置(内存)】

    物理内存碎片:// 不可用的物理内存,包括内部碎片(能明确指出属于哪个进程)和外部碎片(不属于任何进程)。

                             内部碎片 --  对象内存对齐

                             外部碎片 --  与页面分配算法有关,频繁的分配与回收内存会导致大量的、连续且小的页面块夹杂在已分配的页面中间

    ③ 托管内存:

    函数级别GC Alloc大小与次数

    ④ 内存相关的问题

    a. 32位系统虚拟内存地址空间不足 

    b. 内存泄漏 

    c. 托管内存用完引用不释放导致无法被gc回收 

    d. 频繁的GC Alloc引发性能问题 

    e. 内存碎片

    f. 内存越界(栈溢出、堆破坏等)

    资源

    资源管理、资源重复率、资源大小、资源动态下载、资源加载卡顿、资源句柄泄露

    显存:纹理、VBO、shader

    包体大小:游戏安装包大小(初始安装包、资源包、动态静默下载)

    启动速度:游戏启动到可交换界面的时间

    载入地图速度:进入游戏地图的时间

    网络响应速度:建立连接的速率、网络传输的速率、服务器的性能

    手游特有指标:

    弱网络:由于网络制式(2G/3G/4G/wifi)之间网速差异大,用户地理位置变动使得网络发生切换,信号被遮挡后强度减弱,人口密集区网络拥塞严重,从而导致网络出现抖动、延时、丢包,甚至断线

    具体应对措施:客户端超时重发(每条消息都带唯一ID)、心跳包探测、断线重连(简化登录鉴权,不用走完整登录流程)、客户端发生crash下次进入提示重回;服务器延迟下线机制

    流量:单位时间内通过网卡的数据总量

    具体应对措施:a. 紧凑协议结构 b. 去掉本地可以计算得到的数据  c. 协议压缩  d. 协议合并  e. 按照优先级来设定不同包的发送频率

    电量:单位时间内消耗的电荷数量

    温度:手机发烫程度

  • 相关阅读:
    vim 配合管道过滤多行记录
    SpringBoot自动配置原理
    SpringBoot零XML配置的Spring Boot Application
    SpringBoot快速开始Hello World
    Java反射机制
    Java网络编程
    Java JDBC
    Java泛型
    Java I/O
    Java集合
  • 原文地址:https://www.cnblogs.com/kekec/p/7724865.html
Copyright © 2011-2022 走看看