不是定位野指针崩溃,而是直接避免野指针崩溃。请教下有没有这样的方案,如果有,麻烦附上解决方案。
1
dcty 2022-06-28 14:29:37 +08:00 via Android
🥱有时候还不如直接让他崩了,否则业务上可能还要做一些原本不应该做的兼容。
|
3
dcty 2022-06-28 14:47:32 +08:00 via Android
@Jihua 哦,那你搜一下吧,七八年前貌似做过,大概就是在全局异常抛出的时候 handle 住不让它退出这样的处理,具体细节忘记了
|
4
darkengine 2022-06-28 14:57:43 +08:00
NSSetUncaughtExceptionHandler ,这个东西没办法阻止 app 崩,但是可以在崩之前做一些操作例如 logging 或者写文件记录下来之类的。
|
5
ysc3839 2022-06-28 15:04:07 +08:00
@darkengine 如果要记录日志的话推荐直接用 Google 的 Crashpad https://crashpad.chromium.org/
|
6
xtinput 2022-06-28 15:05:06 +08:00
实现 NSObject 的消息转发能避免一部分,那个指针如果刚好指向一个 NSObject 对象就避免了,否则避免不了了
|
7
icyalala 2022-06-28 15:21:11 +08:00
线上野指针可能会产生各种各样的 signal ,你防不住的
|
8
darkengine 2022-06-28 15:39:14 +08:00
@ysc3839 貌似 iOS 的还没完成哎
|
9
ecloud 2022-06-28 15:42:46 +08:00
oc 本质上就是加了个 rc 的 c ,没有 vm ,你兜不了底的。任何企图兜底的方式也大体上差不多是实现了一定程度 vm 的功能了
|
10
ysc3839 2022-06-28 15:51:37 +08:00
@darkengine 好像有? https://chromium.googlesource.com/crashpad/crashpad/+/HEAD/doc/ios_overview_design.md
实在不行还可以试试 Breakpad |
11
txx 2022-06-28 15:56:49 +08:00 1
请用 Swift
|
12
siajia 2022-06-28 16:07:04 +08:00 via iPhone
有啊,思路大概是 hook dealloc 然后替换 isa 指针。具体实际应用还有很多细节,加开关针对特定类,缓存机制,上报机制等等,也有缺点,会造成内存延时释放。 找了一篇文章供参考 http://gonghonglou.com/2019/07/06/crash-guard-bad-access/
|