有没有 Objective-c 访问野指针崩溃的兜底方案(即如何避免野指针崩溃)?

Jihua1月前0

不是定位野指针崩溃,而是直接避免野指针崩溃。请教下有没有这样的方案,如果有,麻烦附上解决方案。

最新回复 (12)
  • dcty1月前
    引用2
  • 楼主Jihua1月前
    引用3
    @dcty 对,一般情况下,应在编码和测试阶段避免野指针;之后收集号线上崩溃日志。
    我这是在准备一道面试题
  • dcty1月前
    引用4
    @Jihua 哦,那你搜一下吧,七八年前貌似做过,大概就是在全局异常抛出的时候 handle 住不让它退出这样的处理,具体细节忘记了
  • darkengine1月前
    引用5
    NSSetUncaughtExceptionHandler ,这个东西没办法阻止 app 崩,但是可以在崩之前做一些操作例如 logging 或者写文件记录下来之类的。
  • ysc38391月前
    引用6
    @darkengine 如果要记录日志的话推荐直接用 Google 的 Crashpad https://crashpad.chromium.org/
  • xtinput1月前
    引用7
    实现 NSObject 的消息转发能避免一部分,那个指针如果刚好指向一个 NSObject 对象就避免了,否则避免不了了
  • icyalala1月前
    引用8
    线上野指针可能会产生各种各样的 signal ,你防不住的
  • darkengine1月前
    引用9
    @ysc3839 貌似 iOS 的还没完成哎
  • ecloud1月前
    引用10
    oc 本质上就是加了个 rc 的 c ,没有 vm ,你兜不了底的。任何企图兜底的方式也大体上差不多是实现了一定程度 vm 的功能了
  • ysc38391月前
    引用11
    @darkengine 好像有? https://chromium.googlesource.com/crashpad/crashpad/+/HEAD/doc/ios_overview_design.md
    实在不行还可以试试 Breakpad
  • txx1月前
    引用12
    请用 Swift
  • siajia1月前
    引用13
    有啊,思路大概是 hook dealloc 然后替换 isa 指针。具体实际应用还有很多细节,加开关针对特定类,缓存机制,上报机制等等,也有缺点,会造成内存延时释放。 找了一篇文章供参考 http://gonghonglou.com/2019/07/06/crash-guard-bad-access/
  • 游客
    14
返回