iOS Crash的收集方式、signal的处理流程、分析问题思路

本文详细介绍了iOS应用中的Crash是如何通过信号触发的,分析了信号处理流程,探讨了Crash日志的关注点,以及如何通过NSUncaughtExceptionHandler捕获异常。同时,文章还分享了在多Crash日志服务共存时的处理策略,并提供了问题分析思路,包括复现问题的方法和根据信号类型定位问题。
摘要由CSDN通过智能技术生成

前言

在iOS上Crash最终都是通过signal的形式发送给应用,应用可以通过注册signal handler来选择处理或忽略大部分信号。

Crash的原因有多种,系统通过不同的signal来告知app这大概是什么原因造成的,常见的信号比如:SIGSEGV,SIGTRAP,SIGABRT

在这里插入图片描述
其中SIGKILL,SIGSTOP信号是无法被捕获或忽略等自定义处理的;

一个crash日志主要关注点

  • 设备和应用信息:Process,Identifier,Version,OS Version
  • 类型:Exception Type即crash信号值
  • 地址:Exception Codes是crash发生的地址信息
  • 问题线程:Triggered by Thread是crash发生的具体线程
  • 问题线程堆栈
  • crashed with ARM Thread State 问题线程寄存器信息
  • Binary Images信息,主要用来堆栈回溯,以及用于定位内存或符号
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

iOS逆向

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值