建议大型项目用上Try Catch建议大型项目用上Try Catch

建议大型项目用上Try Catch

我们在平时项目做功能的时候,经常会遇到崩溃的情况。如果是我们在开发测试阶段,我们可以找到原因修复。但是遇到已经上线,出现这种问题。要么使用JSPatch进行热修复,但是使用热修复修复苦只有写的人知道。

本来就是一个方法一个单词写错,一个值没做异常处理,就要重写整个方法。对于像我这样根本不懂JS语法和不精通JSPatch的人来说,真的是蓝瘦,香菇。

最近写的项目用Swift语法进行编写的,对于之前我们在Object-CNSError**类型的指针标识遇到了什么错误,现在转成Swift方法直接进行throws进行抛异常。

这样我们就必须使用Do Catch进行捕获异常了,我觉得苹果这样做真的挺好的。

比如我刚刚写的项目,就用上了,感觉用完顿时高大上了许多。

import Cocoa

enum OFileMagerImportError:Error {
  case cannel //点击了取消的按钮
  case error(message:String)
}

class OFileManger: NSObject {
  /*
   * 导入配置文件
   * return 返回一个数组对象 可能返回为空
   */
  class func importAction() throws -> [Any] {
      let openPannel = NSOpenPanel()
      openPannel.allowedFileTypes = ["ork"]; // 只允许读取.ork的文件类型
      openPannel.allowsMultipleSelection = false // 设置不允许多选
      let buttonIndex = openPannel.runModal()
      guard buttonIndex == NSFileHandlingPanelOKButton else {
          throw OFileMagerImportError.cannel
      }
      guard openPannel.urls.count > 0 else {
          throw OFileMagerImportError.error(message:"你还没有选择任何的配置文件!")
      }
      guard let fileName = openPannel.urls.first else {
          throw OFileMagerImportError.error(message:"你还没有选择任何的配置文件!")
      }
      guard let jsonData = try? Data(contentsOf: fileName) else {
          throw OFileMagerImportError.error(message:"读取文件内容失败!")
      }
      guard let jsonObj = try? JSONSerialization.jsonObject(with: jsonData, options: .allowFragments) else {
          throw OFileMagerImportError.error(message:"配置文件内容不是一个JSON文本!")
      }
      guard let configList:[Any] = jsonObj as? [Any] else {
          throw OFileMagerImportError.error(message:"配置文件内容不是一个数组对象!")
      }
      return configList
  }


}

调用的时候我们可以这么写。

@IBAction func importAction(_ sender: Any) {
        do {
            let configList:[Any] = try OFileManger.importAction()
            print(configList)
        } catch OFileMagerImportError.error(let message) {
            OAlertMessage.alert(message: message)
        } catch {
            print("抛出了其他不给用户看到的错误!")
        }
    }

我们就可以做一些错误的处理。但是只是这样,我心里面还不是十分强烈想用。

后来线上的App在双11那天晚上突然出现打不开崩溃的情况,在外面准备吃饭庆祝的强行喊回去解决问题。

回去觉得应该是那里崩溃了吧,应该也是十分的容易解决。

后来发现因为接口因为最近上线的功能出问题了,就回滚了代码。导致之前一些接口的字段没有返回,恰好那个接口没有用Model进行映射,所以就出现崩溃了。

经理一直问这个接口回滚好几天了为啥突然出问题了,原来是接口做了缓存,会根据后台返回是否需要更新才会重新的请求接口。

双11那天正好运维更新了数据,导致接口重新请求,少了字段导致崩溃。最后让后台强行把拿两个字段返回,最快的解决问题。

虽然让后台加上了字段,但是我觉得我们App这里没有做好兼容,才导致这一次事故。幸亏没影响多久,再说客户都是外国人,那个时间还没睡醒。

我们平时遇到的一些崩溃问题所在

  • 数组越界
  • 给一个可变数组强行赋值不可变,之后当做可变数组用
  • 字典值不存在
  • 后台返回的字段不统一,本来有值是字典,没值是字符串。

导致的崩溃自然不止这些,但是这些占据了崩溃里面大部分,前三个我们可以做一下异常处理,最后一个最好还是让后台规范起来,这是长远之际。或者使用Model进行映射。

怎么做异常处理

  • 做很多if else判断
  • 使用Try catch进行处理

虽然两个都要写很多的代码,if else的代码更加优美一点,但是就怕有一种情况你没写出来。觉得最好的办法还是用try catch进行。

@try@catch@throw,和 @finally。这四个关键词进行异常处理。

我们看一下常见的一个数组越界的例子:

NSArray *tests = @[];
NSNumber *num = tests[0];

我们不用运行就可以知道这个地方会崩溃,因为我们初始化的数组是空的。但是我们强行取一个元素,导致崩溃。

假设我们现在用上了try catch的代码,会如何呢。

NSArray *tests = @[];
@try {
    NSNumber *num = tests[0];
} @catch (NSException *exception) {
    NSLog(@"%@",exception.userInfo);
} @finally {
    NSLog(@"我做一些必须的处理");
}

经过测试,这个代码会在Debug的时候断点,但是强行运行还是可以运行的。但是在Release发布之后运行完全没有任何的影响。

虽然我们平时写代码上面,不可能让所有出现异常的地方写上这样的代码。但是对着我们的经验,我们对于一眼就知道会出崩溃的地方加上,还是能让线上的应用少出很多问题的。

关于Try catch的资料可以查看下面资料:

iOS捕获异常,常用的异常处理方法

Swift中错误和异常处理

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏何俊林

阿里、华为、腾讯Java技术面试题精选

1845
来自专栏开发技术

shiro源码篇 - shiro的session的查询、刷新、过期与删除,你值得拥有

    老公酷爱网络游戏,老婆无奈,只得告诫他:你玩就玩了,但是千万不可以在游戏里找老婆,不然,哼哼。。。     老公嘴角露出了微笑:放心吧亲爱的,我绝对不会...

3512
来自专栏JackeyGao的博客

用户Python3解析超大的csv文件

我在日前获得一个任务,为了做分析, 从一个超大的csv文件中解析email地址和对应的日期时间戳然后插入到数据库中. 我知道有其他工具可以方便的完成我的工作(比...

1052
来自专栏农夫安全

代码审计之命名执行漏洞

环境:windows + apache + mysql + php (phpstudy) 由于是在Windows下进行的测试,所以和Linux下的测试会有所不...

2976
来自专栏运维一切

ceph对象存储折腾记 原

###前言 一直想弄对象存储,以前弄过一次,不是很理解region是个什么东西,后来时间和工作上的原因没有再折腾,这两天闲了下来,再次折腾了一次。我是参考的ce...

1681
来自专栏大史住在大前端

webpack4.0各个击破(5)—— Module篇

使用webpack对脚本进行合并是非常方便的,因为webpack实现了对各种不同模块规范的兼容处理,对前端开发者来说,理解这种实现方式比学习如何配置webpac...

1322
来自专栏大闲人柴毛毛

轻量级线程池的实现

写在前面 最近因为项目需要,自己写了个单生产者-多消费者的消息队列模型。多线程真的不是等闲之辈能玩儿的,我花了两个小时进行设计与编码,却花了两天的时间调试与运...

5254
来自专栏安恒网络空间安全讲武堂

从零基础到成功解题之0ctf-ezdoor

2174
来自专栏SDNLAB

ODL应用开发之MD-SAL中级教程

1. 简介 本次我们从开始设计到最终完成一个应用的开发,主要设计datastore和RPC定义和实现。Opendaylight 开发使用了OSGi框架,OSGi...

7508
来自专栏积累沉淀

Java批处理

批处理 JDBC对批处理的操作,首先简单说一下JDBC操作sql语句的简单机制。 JDBC执行数据库操作语句,首先需要将sql语句打包成为网络字...

4755

扫码关注云+社区

领取腾讯云代金券