当前位置: 首页 > news >正文

通过Bugly上报的日志查找崩溃闪退原因

第一步,解析堆栈信息

在bugly上收集到的信息是这样的

0x000000010542e46c 0x0000000104db4000 + 6792300

OS应用发生崩溃时,系统会生成一份崩溃日志,这份日志中包含了崩溃时的堆栈信息,但这些堆栈信息并非直接指向源代码,而是以16进制的地址表示,这就需要我们进行反向符号化操作来定位具体的代码行数。

以下是具体的步骤:

1. 打开终端,cd到Xcode的"Developer"目录下,如:

```
cd /Applications/Xcode.app/Contents/Developer
```
2. 执行以下命令进行反向符号化:

```
./usr/bin/atos -o [dSYM文件的路径]/Contents/Resources/DWARF/[应用的名字] -l [内存基地址] [要转换的地址]
```

其中:
- [dSYM文件的路径]: dSYM文件是在编译时生成,用于存储应用的调试符号信息,通常和.ipa文件在同一目录下。
- [应用的名字]: 你的应用名字,该值需要和dSYM文件的名字一样。
- [内存基地址]: 崩溃堆栈信息中的内存基地址。
- [要转换的地址]: 崩溃堆栈信息中你要转换的那个地址。

这样就可以找到对应的源代码行数了。

需要注意的是,这种方法只适用于你有dSYM文件的情况下,如果没有,则需要使用其他方式,如在开发阶段打开Xcode的异常断点等方法。

例如:

cuixiang@Cuis-Mac-mini ~ % cd /Applications/Xcode.app/Contents/Developer

cuixiang@Cuis-Mac-mini Developer % ./usr/bin/atos -o "/Users/cuixiang/Documents/twig/twig-mobile.app.dSYM/Contents/Resources/DWARF/twig-mobile" -l 0x0000000102e38000 0x0000000103356514

得到具体的堆栈如下

cocos2d::LuaBridge::pushLuaFunctionById(int) (in twig-mobile) + 116

第二步,分析崩溃时内存占用,发现崩溃时内存剩余5%一下

第三步,查看内存和调用堆栈,通过分析波峰堆栈,查找内存增长的点,这里发现是spine相关的API,在相关调用地方加日志发现缓存失效,每次都重新创建新的spine,而旧的有没释放。进一步查找发现失效的原因是切换场景时置空了缓存池table,同样的在AndroidStudio上查看也是同样的内存涨幅,androidstudio查看内存情况看这里。


可以发现,通过调整每次进出游戏后加载的资源都释放了

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Rust: 关于Pin以及move前后分析
  • Python基础-循环语句
  • 安全防御,防火墙配置NAT转换智能选举综合实验
  • 在家上网IP地址是固定的吗?
  • Is Temperature the Creativity Parameter of Large Language Models?阅读笔记
  • GitHub+Picgo图片上传
  • Web学习day04
  • 未来互联网的新篇章:深度解析Facebook的技术与战略
  • rust way step 1
  • 宏碁F5-572G-59K3笔记本笔记本电脑拆机清灰教程(详解)
  • 中职网络安全B模块渗透测试server2003
  • 解释如单例、工厂、观察者等常见设计模式在Android开发中的应用。
  • kali安装vulhub遇到的问题及解决方法(docker及docker镜像源更换)
  • 两段序列帧动画播放,在ios机型上出现闪屏
  • python的字符串
  • 《Javascript高级程序设计 (第三版)》第五章 引用类型
  • 【mysql】环境安装、服务启动、密码设置
  • ES2017异步函数现已正式可用
  • ES6系统学习----从Apollo Client看解构赋值
  • Git 使用集
  • HTML5新特性总结
  • IDEA 插件开发入门教程
  • IndexedDB
  • JS数组方法汇总
  • js数组之filter
  • mac修复ab及siege安装
  • rabbitmq延迟消息示例
  • Vue全家桶实现一个Web App
  • XML已死 ?
  • 浮动相关
  • 机器学习学习笔记一
  • 基于Volley网络库实现加载多种网络图片(包括GIF动态图片、圆形图片、普通图片)...
  • 记录:CentOS7.2配置LNMP环境记录
  • 那些被忽略的 JavaScript 数组方法细节
  • 使用 Docker 部署 Spring Boot项目
  • 微信小程序填坑清单
  • #C++ 智能指针 std::unique_ptr 、std::shared_ptr 和 std::weak_ptr
  • (4) PIVOT 和 UPIVOT 的使用
  • (AtCoder Beginner Contest 340) -- F - S = 1 -- 题解
  • (delphi11最新学习资料) Object Pascal 学习笔记---第8章第2节(共同的基类)
  • (初研) Sentence-embedding fine-tune notebook
  • (第9篇)大数据的的超级应用——数据挖掘-推荐系统
  • (动手学习深度学习)第13章 计算机视觉---微调
  • (二十五)admin-boot项目之集成消息队列Rabbitmq
  • (附源码)springboot建达集团公司平台 毕业设计 141538
  • (含笔试题)深度解析数据在内存中的存储
  • (三)终结任务
  • (生成器)yield与(迭代器)generator
  • (转)Android学习系列(31)--App自动化之使用Ant编译项目多渠道打包
  • (转)C#开发微信门户及应用(1)--开始使用微信接口
  • .【机器学习】隐马尔可夫模型(Hidden Markov Model,HMM)
  • .Net Core 中间件验签
  • .NET 同步与异步 之 原子操作和自旋锁(Interlocked、SpinLock)(九)
  • .NET 指南:抽象化实现的基类
  • .NET版Word处理控件Aspose.words功能演示:在ASP.NET MVC中创建MS Word编辑器