NSSetUncaughtExceptionHandler处理异常

在阅读《高性能iOS应用开发》的时候,看注释提到了NSSetUncaughtExceptionHandler这个类,简单了了解了一下。终于明白如友盟Buggly等软件异常捕获是如何实现的。

说明

利用NSSetUncaughtExceptionHandler可以用来处理异常崩溃。崩溃报告系统会用NSSetUncaughtExceptionHandler方法设置全局的异常处理器。

如果自定义NSSetUncaughtExceptionHandler监听事件,会导致第三方监听失效,需要注意。

用法

void UncaughtExceptionHandler(NSException *exception) {
    NSArray *arr = [exception callStackSymbols];
    NSString *reason = [exception reason];
    NSString *name = [exception name];
    NSLog(@"%@\n%@\n%@",arr, reason, name);
}

- (BOOL)application:(UIApplication *)application didFinishLaunchingWithOptions:(NSDictionary *)launchOptions {
    // Override point for customization after application launch.
    NSSetUncaughtExceptionHandler(&UncaughtExceptionHandler);

    NSArray *arr = @[@(0), @(1)];
    NSLog(@"%@", arr[2]); //模拟越界异常   
    return YES;
}

运行结果(如图):
这里写图片描述

通过使用别的方法也可以激活异常:
[NSException raise:@”Crash Button Was Clicked” format:@”“];

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue2项目的目录结构通常如下: ``` ├── build // 项目构建相关的代码 │ ├── build.js // 生产环境构建代码 │ ├── check-versions.js // 检查node、npm等版本 │ ├── dev-client.js // 开发服务器热重载配置 │ ├── dev-server.js // 开发服务器配置 │ ├── utils.js // 构建相关工具方法 │ ├── webpack.base.conf.js // webpack基础配置 │ ├── webpack.dev.conf.js // webpack开发环境配置 │ └── webpack.prod.conf.js // webpack生产环境配置 ├── config // 项目开发环境配置 │ ├── dev.env.js // 开发环境变量 │ ├── index.js // 项目配置文件 │ ├── prod.env.js // 生产环境变量 │ └── test.env.js // 测试环境变量 ├── src // 源码目录 │ ├── assets // 资源目录,如图片、字体等 │ ├── components // 公共组件目录 │ ├── router // 前端路由 │ ├── store // 应用级数据(state)管理目录 │ ├── utils // 工具函数目录 │ ├── views // 页面目录 │ ├── App.vue // 主组件 │ └── main.js // 入口文件 ├── static // 静态资源目录,如图片、字体等 ├── test // 测试相关目录 ├── .babelrc // babel配置文件 ├── .editorconfig // 定义代码格式 ├── .eslintignore // eslint忽略目录或文件 ├── .eslintrc.js // eslint配置文件 ├── .gitignore // git忽略目录或文件 ├── .postcssrc.js // postcss配置文件 ├── index.html // 项目入口文件 └── package.json // 项目基本信息 ``` 其,`build`目录存放构建相关的代码,`config`目录存放项目开发环境的配置,`src`目录存放源码,`static`目录存放静态资源,`test`目录存放测试相关的代码。 `src`目录下,`assets`目录存放各种资源文件,如图片、字体等;`components`目录存放公共组件;`router`目录存放前端路由相关代码;`store`目录存放应用级数据(state)管理相关代码;`utils`目录存放工具函数相关代码;`views`目录存放页面相关代码;`App.vue`是主组件;`main.js`是入口文件。 以上是一个常见Vue2项目目录结构,具体项目可能会略有差异。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值