最近的项目是使用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
来访问该方法。
暂时就先总结了这么多,后续有的话再继续讲解。
网友评论