QYCrashProtector
应用程序因服务端数据返回异常、未实现方法等问题导致崩溃的情况比比皆是,尽管有经验的开发者可以通过一些 if 判断增加一层保护,但总觉得不够优雅;而且如果面对前人留下的代码呢... 显然一个个加判断有点力不从心...
在此基础上,有幸看到了此作者的文章---链接戳这里,全面分析了导致崩溃的各种原因,这里不再赘述... 但遗憾的是,作者并未开源代码...
基于以上情况,本人的 QYCrashProtector(崩溃保护工具)应运而生!!! 开源,但有不完善的地方,希望广大开发者看到后积极提出宝贵意见,让我们共同努力,向崩溃说再见~
在此感谢@ibireme!!! 工具中的 timer 保护类,引用了 YYWeakProxy 类打破 retainCycle。(由于 QYCrashProtector 库中引入的 YYWeakProxy 会与 YYKit 库重名冲突,特此将项目中引入的 YYWeakProxy 进行重命名处理。)
使用方法
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions
方法开启 crash 保护;
可以在程序一启动时就通过 当然也可以在任何想要开启的地方开启,早开早用;
开启方法:
- 步骤 1:导入头文件:
#import <QYCrashProtector.h>
; [QYCrashProtector qy_openAllCrashProtector];
开启所有类型保护。
注意事项:
- 该工具的开放入口为
#import <QYCrashProtector.h>
, 只需导入该头文件就可使用所有功能; QYCrashProtector.h
类中包含对应的开启保护类型的方法,可自行搭配使用;- 本工具主要采用了
method swizzling
的方式, 原工程不需要任何修改; - 目前支持 timer/ unrecognized selector/ NSArray/NSMutableArray/NSDictionary/NSMutableDictionary/NSCache / String系列等的保护;
- 因KVO、NSNotification、BAD_ACCESS的保护方法存在一些问题,暂未提供;
- 当捕捉到异常时,会通过
QYErrorLog
类中的相关方法打印出来; - 每种类型的保护放在对应的分类中,便于拓展和维护。详情请查看源码。
示例
- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
// open all crash protector.
[QYCrashProtector qy_openAllCrashProtector];
// or:
// open unrecognized selector protector.
[QYCrashProtector qy_openCrashProtector_unrecognized_selector];
// open timer protector.
[QYCrashProtector qy_openCrashProtector_timer];
// open container protector.
[QYCrashProtector qy_openCrashProtector_container];
// open string protector.
[QYCrashProtector qy_openCrashProtector_string];
// open UI protector.
[QYCrashProtector qy_openCrashProtector_UI];
...
要求
安装
QYCrashProtector 可通过 CocoaPods 获取。要安装它,只需在 Podfile 中添加以下行
pod 'QYCrashProtector'
作者
许可证
QYCrashProtector 可在 MIT 许可下使用。有关更多信息,请参阅 LICENSE 文件。