QYCrashProtector 1.0.7

QYCrashProtector 1.0.7

Joeyoung 维护.



  • 作者:
  • joeyoung

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'

作者

joeyoung,

许可证

QYCrashProtector 可在 MIT 许可下使用。有关更多信息,请参阅 LICENSE 文件。