位置: 编程技术 - 正文

手游频繁崩溃”闪退”? 从程序上找原因(手游频繁崩溃怎么解决)

编辑:rootadmin
手游频繁崩溃”闪退”? 从程序上找原因 作为玩家,当游戏crash的时候是什么心情,如果这个游戏玩起来还不错的话,那我可能还会打开第二次,如果这个游戏一般的话我可能直接怒删了。当多次出现闪退crash的时候,这种糟糕的体验很容易让用户流失,造成很大的损失。但是作为测试人员,面对如此棘手的事情,首先要做的是协助开发组解决问题。没错,第一件要做的事情就是去定位crash发生的代码逻辑,到底是哪个文件的哪一段函数逻辑导致了这个crash问题。因此,我们需要去尽量重现crash场景,收集解析crash日志,以此定位到具体到游戏代码逻辑中寻找导致crash的原因,改善项目的质量和体验。本文阐述在App crash产生的原理,收集和解析过程,旨在经验积累,与大家分享。  一.crash产生的原因  当iOS/Android设备上的App应用闪退时,操作系统会生成一个crash日志,保存在设备上。crash日志上有很多有用的信息,比如每个正在执行线程的完整堆栈跟踪信息和内存映像,这样就能够通过解析这些信息进而定位crash发生时的代码逻辑,从而找到App闪退的原因。通常来说,crash产生来源于两种问题:违反iOS系统规则导致的crash和App代码逻辑BUG导致的crash,下面分别对他们进行分析。  1.1违反iOS系统规则包括三种类型:  (1) 内存报警闪退  当iOS检测到内存过低时,它的VM系统会发出低内存警告通知,尝试回收一些内存;如果情况没有得到足够的改善,iOS会终止后台应用以回收更多内存;最后,如果内存还是不足,那么正在运行的应用可能会被终止掉。在Debug模式下,可以主动将客户端执行的动作逻辑写入一个log文件中,这样程序童鞋可以将内存预警的逻辑写入该log文件,当发生如下截图中的内存报警时,就是提醒当前客户端性能内存吃紧,可以通过Instruments工具中的Allocations 和 Leaks模块库来发现内存分配问题和内存泄漏问题。

推荐整理分享手游频繁崩溃”闪退”? 从程序上找原因(手游频繁崩溃怎么解决),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:手游频繁崩溃怎么回事,手游一直闪退什么原因,手游频繁崩溃怎么回事,手游频繁崩溃怎么解决,手游频繁崩溃怎么解决,手游频繁崩溃怎么回事,手游频繁崩溃怎么回事,手游频繁崩溃怎么办,内容如对您有帮助,希望把文章链接给更多的朋友!

  (2) 响应超时  当应用程序对一些特定的事件(比如启动、挂起、恢复、结束)响应不及时,苹果的Watchdog机制会把应用程序干掉,并生成一份相应的crash日志。这些事件与下列UIApplicationDelegate方法相对应,当遇到Watchdog日志时,可以检查上图中的几个方法是否有比较重的阻塞UI的动作。  application:didFinishLaunchingWithOptions:  applicationWillResignActive:  applicationDidEnterBackground:  applicationWillEnterForeground:  applicationDidBecomeActive:  applicationWillTerminate:  (3) 用户强制退出  一看到“用户强制退出”,首先可能想到的双击Home键,然后关闭应用程序。不过这种场景一般是不会产生crash日志的,因为双击Home键后,所有的应用程序都处于后台状态,而iOS随时都有可能关闭后台进程,当应用阻塞界面并停止响应时这种场景才会产生crash日志。  这里指的“用户强制退出”场景,是稍微比较复杂点的操作:先按住电源键,直到出现“滑动关机”的界面时,再按住Home键,这时候当前应用程序会被终止掉,并且产生一份相应事件的crash日志。  1.2应用逻辑的Bug  大多数闪退崩溃日志的产生都是因为应用中的Bug,这种Bug的错误种类有很多,比如  SEGV:(Segmentation Violation,段违例),无效内存地址,比如空指针,未初始化指针,栈溢出等;  SIGABRT:收到Abort信号,可能自身调用abort()或者收到外部发送过来的信号;  SIGBUS:总线错误。与SIGSEGV不同的是,SIGSEGV访问的是无效地址(比如虚存映射不到物理内存),而SIGBUS访问的是有效地址,但总线访问异常(比如地址对齐问题);  SIGILL:尝试执行非法的指令,可能不被识别或者没有权限;  SIGFPE:Floating Point Error,数学计算相关问题(可能不限于浮点计算),比如除零操作;  SIGPIPE:管道另一端没有进程接手数据;  常见的崩溃原因基本都是代码逻辑问题或资源问题,比如数组越界,访问野指针或者美术资源不存在,或美术资源大小写错误等,这种问题的类型有很多,不再详细介绍。  二.crash的收集  上文提到crash日志是操作系统层产生并保存在设备上的,那如果我的一台设备在运行某App的时候crash了,可以通过什么方式拿到crash日志呢。如果是在windows上你可以通过itools或pp助手等辅助工具查看系统产生的历史crash日志,然后再根据app来查看。如果是在Mac 系统上,只需要打开xcode->windows->organizer->devices,选择device logs进行查看,如下图,这些crash文件都可以导出来,然后再单独对这个crash文件做处理分析。

  以上这些是针对能够拿到真机设备的情况下才能收集crash日志的。如果是针对玩家的话,当App在玩家的设备上crash的时候如何收集呢。先来看下市场上已有的商业软件提供crash收集服务,他们这些软件基本都提供了日志存储,日志符号化解析和服务端可视化管理等服务:  Crashlytics (www.crashlytics.com)  Crittercism (www.crittercism.com)  Bugsense (www.bugsense.com)  TestFlight (www.testflightapp.com)  HockeyApp (www.hockeyapp.net)  Flurry(www.flurry.com)  具体这些商业软件有哪些优缺点,有人做了如下统计:手游频繁崩溃”闪退”? 从程序上找原因(手游频繁崩溃怎么解决)

  除了上述所说的这些商业软件外,还有一些开源的软件也可以拿来收集crash日志,比如Razor,QuincyKit(git链接)等,这些软件收集crash的原理其实大同小异,都是根据系统产生的crash日志进行了一次提取或封装,然后将封装后的crash文件上传到对应的服务端进行解析处理。很多商业软件都采用了Plcrashreporter这个开源工具来上传和解析crash,比如HockeyApp,Flurry和crittercism等,下图是笔者利用这一开源框架制作的一个收集crash的样例。

  通过这种方式就可以很好的支持开发人员收集crash日志的需求,进而定位和解决App产品存在的问题。如果有需要或者感兴趣的可以深入的调研一下。  但是有个很重要的问题就是这种方式只能收集游戏引擎层(c&#;&#;或object c代码)的逻辑,如果是脚本逻辑问题产生的crash就无能无力了。而现在手游项目基本都是引擎(cocos2dx或Neox)&#;脚本(lua或javascript)的开发模式,几乎所有的业务逻辑都在脚本层,游戏App时常发生的crash几乎都是由脚本逻辑bug导致的,这该怎么处理呢?平时在开发阶段,程序童鞋在Debug模式下开通了客户端运行日志功能,当出现crash或者traceback等问题的时候直接去查看log文件的输出即可知道原因了,但是在Release模式下一切log输出均被屏蔽,逻辑运行的log消息输出也就无法查看了。这种情况该又该如何处理呢?方法总比问题多,iOS/Android系统提供了异常发生时的处理API,只需要在程序启动的地方加入对应的处理逻辑,当异常发生时就可以触发对应的回调函数将必要的信息进行处理上传,适时地反馈给开发组。比如,下图是某项目组在iOS平台收集crash的一个截图:

  其实,它具体的实现原理是这样的:首先,在游戏应用程序启动的地方需要开启异常处理逻辑的handler:

  最后需要当crash发生时,需要调用的回调函数处理具体如下:

  这样在当玩家在Release游戏版本中出现逻辑异常导致crash时,就会把对应的脚本层的异常(traceback或error等)以类&#;dump文件的形式发送到指定的服务端,方便运营维护人员进行快速定位分析。这些脚本层异常日志收集后的显示效果如下:  以具体某一个异常日志文件为例,具体上传的内容如下图。这是一种直接可读的文本,里面记录着crash发生时代码逻辑的traceback,通过阅读代码逻辑就可以直接定位到或推断导致crash

  

标签: 手游频繁崩溃怎么解决

本文链接地址:https://www.jiuchutong.com/biancheng/372809.html 转载请保留说明!

上一篇:uGUI实现遥感(unet遥感图像分割)

下一篇:一款已上市MMO手游地图同步方案总结(及将上市的手机)

  • 资金预算表编制依据
  • 实缴时间不能超过申请时间怎么办
  • 免税收入不征税收入有哪些
  • 委托外单位研发的研发费用加计扣除最新政策
  • 企业贷款合同签订后多久放款
  • 税款必须要15号之前交吗
  • 收到固定资产抵账增值税计税基础
  • 单位补缴社保会罚款吗
  • 旧机动车交易需要哪些法定证件
  • 虚开发票的受票企业将会受到什么处罚?
  • 外贸企业购进固定资产进项税能留存吗
  • 旅游服务费可以抵扣增值税
  • 不得抵扣且未抵扣什么意思
  • 公车私用情形有哪些
  • 公司前三季度实现营业收入59.17亿元
  • 新注册的个体户怎么开发票
  • 小规模纳税人需要做账吗
  • 店面转让出去收到的钱如何做账?
  • 出纳汇错款会计怎么做账
  • 出口退税是几个点
  • 取得劳务费的账务处理
  • 电脑换系统怎么备份软件
  • win7桌面快捷键是什么
  • 公务车加油入什么科目
  • 对外捐赠款属于什么会计科目
  • 厂房维修是否可以退税
  • 处置子公司税务处理
  • 上月开的发票会计漏做帐本月应如何补做账?
  • sistray.exe - sistray是什么进程 有什么用
  • 给实习生发放工资怎么纳税?
  • 流转税政策
  • 最奢华的女士腕表
  • shell脚本攻略第三版pdf
  • 免征个人所得税33种情形
  • vue切换背景图片
  • 增值税达不到起征点账务处理
  • 月底结转汇兑损益
  • cesium description
  • css常见的选择器有哪几种
  • js框架jquery
  • 小三用英语怎么写?
  • 公司扣个税查不到怎么办
  • 费用化支出期末一般转入哪个账户?
  • 开具电费发票如何入账
  • 无票收入如何报税
  • 以前未入账固定资产补入账
  • 认缴制无实收资本怎么算
  • 出差补贴要不要交个税呢?
  • 社会保险分割单怎么查
  • ibm db2认证
  • 开专用发票可以直接写加工费这个明细吗?
  • 计提工会经费并上缴是什么意思
  • 合作社增值税免税项目
  • 资产减少的方式有哪些?
  • 红字申请单如何打印出来
  • 子公司计提的盈余公积合并抵消
  • 困难行业企业包括哪四大类
  • 税务局退回水利基金账务怎么处理
  • 如何理解会计的本质
  • 什么时候确认应收
  • 筹建期业务招待费的扣除标准
  • 工程费用科目
  • 工程内部承包合同
  • 重要空白凭证是什么科目
  • 互联网代记账业务
  • 注册表regsz是什么意思
  • win7怎么彻底删除文件
  • rhel7.4安装
  • win7系统玩英雄联盟蓝屏
  • win8怎么开启蓝牙
  • 怎么用unity做游戏
  • 置顶聊天折叠怎么开启
  • unity账号登录
  • [置顶]bilinovel
  • vue实现滚动条
  • 浅谈 vue 中的 watcher
  • jquery 滑动显示
  • flask框架代码
  • 外地人在上海奉贤区买房需要什么条件
  • 村级服务公开的具体内容
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设