iOS开发资料收集区iOS学习坚持写

SwiftyJSON源代码学习(一)

2017-03-07  本文已影响0人  YinSJ

为什么选择SwiftyJSON

要精通一门语言,阅读优秀的源代码是一条非常好的捷径,只凭借着基本的语法和教程学习,然后一点点去试错、去填坑来精进这门语言的修为,不可取也。
要阅读、精研源代码,就要选择优秀的源码来读,“取法乎上仅得其中,取法乎中仅得其下”。除此之外,最好选择实用的、使用频率高的项目,能在此学习中同时精进语言和实际开发水平,才是上上之选。
SwiftyJSON,作为一个13000+star的开源swift项目,在质量和实用性上是毋庸置疑的。并且该项目只有1000多行代码,作为我们阅读分析的第一个项目,我已经找不出更合适的了。

SwiftyJSON有什么功能

当我们从服务端取到数据并序列化为JSON后,从JSON到Model的这一过程是很痛苦的,为了使APP不仅仅因为后台的数据有一点点问题就崩溃掉,我们需要在取每个值的时候都小心翼翼的去进行空值和类型判断,表现在代码上就是一大堆的if...else或者guard...else,不仅繁琐,而且非常容易出现疏忽。
SwiftyJSON可以通过Data或String对象实例化JSON对象,之后对此JSON对象可以以链式语法的形式,一层一层的取数据,并最终转化为我们想要的数据类型。如果没有指定的JSON数据或类型不匹配会返回nil,方便快捷,并且怎么玩都不会crash。

SwiftyJSON源代码结构分析

除了提供各平台适应性的支持文件外,源代码就放在了SwiftyJSON.swift这一个文件里。
其结构为:

  1. JSON结构体,定义了JSON的数据结构和构造方法
  2. 索引和集合,下标,字面值,控制台打印等基于Swift标准库协议的特性实现
  3. 以RowValue的形式把JSON数据转化为用户想要的数据类型
  4. 运算符重载实现JSON数据的比较

后面我也将以此为索引,分4篇文章分析,在此之前,我们可以来聊聊一些边边角角的东西。

关于注释

代码其实是写给两类人看的:

为了提升代码的可读性,注释无疑是最有效的方法之一,而写出可读性高的代码,不仅仅是一种态度和责任,更是有着现实的收益——阅读你的代码最多的人,肯定是你自己。
swift中的注释格式,有如下5种,我们应该在开发过程中根据情况综合应用:

知识点一:给代码加上必要的注释以提高可读性。用// MARK: -形式的注释划分代码结构,对于开放给用户的接口,更应以////** */的形式的注释,使得Xcdoe能提供足够多的接口信息给用户

关于访问权限

当我们在写每一个类、枚举、属性、函数等任何单元时,第一个要考虑的就应该是其访问权限的问题,面向对象思想的基础是封装抽象,如果在外部可以无视对象封装随意访问甚至修改对象内部结构,这种代码将会变得非常难以维护,而且极有可能是随时会爆炸的定时炸弹。
swift中的访问权限有如下5种,我们应该尽量使用最低的权限:

swift的默认访问权限是internal

知识点二:尽量以最低的访问权限来设计接口,更要通过思考访问权限问题,来努力保持抽象的一致性和对象的封装性

关于宏

出于安全性的考虑,swift中并没有加入宏的功能,对于简单的值类型的宏,可以直接通过let定义一个常量代替。实际上在OC开发中,更好的方式也是通过定义一个类似于const NSString * ErrorDomain的常量来获得更多的类型检测。

上一篇下一篇

猜你喜欢

热点阅读