最近的项目是使用Swift进行的开发,在开发过程中,有一些东西和OC是不太一样的,需要特别的注意,这里也就简单的介绍和记录一下。
1. 单例模式
在OC中的单例模式一般都是使用dispatch_once来实现的,可是在Swift4中,该方法已经被废弃,也就是说单例模式的实现和之前不再一样。在Swift中,单例的实现是通过静态成员和let关键字来实现的,具体代码如下:
class ClassA {
static let `default` = ClassA()
}
ClassA.default //用来访问单例对象
可以看到,在使用default的时候加了``` 符号,这是由于default是保留关键字,如果使用其他名字,如shared`,则直接使用变量名即可。
2. OptionalValue,if let
OptionalValue可以说是Swift的标志了,只要知道Swift的人,都知道Swift语言中的?和!,他们具体的含义,这里无需多说,只是要说,如果类成员属性的话,一定要选好类型,还有就是如果定义成了!类型,注意使用之前一定要赋值,因为编译器不会进行检查。
if let,还有就是guard let else,其实都是一个意思,就是if let a = b, let c = a.func(),如果b是一个OptionValue,那么当值为nil时,条件不成立;,的作用类似于&&,但是不能使用&&,因为let语句并没有返回值。还有一种情况,就是if var a = b也是可以使用的,和if let含义相同。
3. @discardableResult
这个就是一个简单的说明,在函数的上方加上这个修饰器,在调用的时候,可以忽略返回值,如果不添加,那么在调用处如果没有使用返回值,Xcode会进行告警。
4. weak
Swift中没有了属性的strong/assign/copy之类的修饰符,但是weak还是存在的,所以这里要注意一下。Swift中class对象的引用默认都是强引用,所以也会存在有循环引用的问题,这个时候,就需要对属性添加weak修饰符,weak修饰的属性是弱引用,这样就可以避免循环引用了。
如果需要在closure中弱引用self,那么可以在参数声明的地方添加[weak self],然后closure中的self就是弱引用了,不过类型也变成了OptionalValue,因为弱引用self,外部self是有可能被释放的,这里需要注意一下。
5. protocol + extension VS class
由于Swift支持了对protocol的函数添加默认实现,所以很多公有基础类就不再需要了,而是可以换成protocol,这样可以变相的实现多继承,特别是可以要求部分方法在类中强制实现,部分方法使用默认实现。
当然,也不是所有的类继承都适合转换为protocol + extension方式,如果需要有存储类型的属性,那么还是使用公共基类比较好。
6. 命名空间
命名空间是一个在OC中不存在的概念,简单的说,就是引入framework的类(或方法),可以在前面加上模块名称,来避免和本地定义的类(或方法)重名。
如引入Alamofire中的方法request,可以使用代码Almafire.request来调用,避免和本地定义的request方法重名导致出现错误;当然,如果本地没有定义request方法,也可以直接调用request来访问该方法。
暂时就先总结了这么多,后续有的话再继续讲解。