Swift开发中遇到的注意点(一)

最近的项目是使用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来访问该方法。

暂时就先总结了这么多,后续有的话再继续讲解。

你可能感兴趣的:(Swift开发中遇到的注意点(一))