首先强烈建议大家安卓打包一定要用il2cpp,我们项目对比了mono发现il2cpp闪退方面比mono少了很多。平常给QA打包推荐勾选Development Build 和 Autocontent Profiler 。这样如果发生了闪退可以直接从log中定位,或者真机连profiler。

我们来看一个闪退的日志

如下图所示,WorldSceneMgr.cs 是我们自己写的c#代码,这里已经可以直接定位在哪一行闪退,通过完整堆栈即可定位到此时的闪退是由于WorldSceneMgr.cs CheckEventGenerator方法调用了物理相关函数,导致unity的物理引擎挂了。


如果是releas正式包,那么在打包的时候必须要将我们自己写的c#代码生成的符号表.so保存下来。保存方法大家可以参考unity的文档

在闪退日志中查询到崩溃地址,使用addr2line即可还原出来。 详细方法同样可以参考unity的文档。

如果你的项目还在使用mono,同样也可以利用上面的方法还原出来崩溃堆栈。

可能大家都会接崩溃汇报的sdk,无论如何我们有带符号表的.so都可以还原崩溃堆栈。平常开发每天都会打包,但是版本号和包名都是一致的。但是每个包的.so文件都不一样,所以在崩溃汇报的时候还需要发送一个唯一的标志,用于日后来做区分。

后来我们又发现一个问题,QA在测试的时候有时候,他们会跑出来崩溃, 或者由于代码报错了导致界面异常或者逻辑异常。由于他们在报 bug的时候没有详细log日志,不太明确的bug技术只能靠猜来改。所以我们由给QA做了个一键提取log的工具。

如图下图所示,技术在自己的android sdk目录下拷贝出 adb.ext  AdbWinApi.dll AdbWinUsbApi.dll fastboot.ext 这些adb需要的依赖库。


脚本就是run.bat


@echooff
set"year=%date:~0,4%"
set"month=%date:~5,2%"
set"day=%date:~8,2%"
set"hour_ten=%time:~0,1%"
set"hour_one=%time:~1,1%"
set"minute=%time:~3,2%"
set"second=%time:~6,2%"
setadb="%~dp0\adb.exe"
echo%adb%
%adb%logcat-vtime-d>%year%%month%%day%%hour_ten%%hour_one%%minute%%second%.log&

QA测试当跑出来bug或者闪退 只要在2分钟内(很短的一段时间)连上电脑, 快速双击 run.bat 就可以自动提取出当前手机的完整log了,在提交bug我们技术看就方便多啦。

注意:如果测试在PC上安装了360手机助手,adb端口就会被占用(强杀360都不行)。需要在360助手设置界面关闭 开机启动 设备连接时提醒我  关闭悬浮框 重启一下电脑。

或者也可以不安装360手机助手,我测试过豌豆荚就没有这问题,或者别的助手也可以,毕竟QA就是手机助手用来装驱动和apk包。 现在我们的测试在提取安卓日志已经很6啦。呼呼~

最后,欢迎大家在下面给我留言,我们互相讨论~

最后编辑:2018-03-20作者:雨松MOMO


专注移动互联网,Unity3D游戏开发