动机
Swift 升级至 3.0 以后,Swift 标准库中移除了对可选类型比较运算符的实现,当我们升级 Swift 版本的时候,可能会出现若干问题,为了代码重构需要,所以重写比较运算符。
代码变更记录
Swift2.3 时代的代码如下
if (self?.monthParams.filter{ return $0.length == 0 })?.count > 0 {
self?.showTip("请输入日期")
}
升级到 Swift3.0 以后,需要这样写
if ((self?.monthParams.filter{ return $0.length == 0 })?.count ?? 0) > 0 {
self?.showTip("请输入日期")
}
-
Tips
- 这里的 > 左右两边的操作数,必须是非可选类型!所以会出现大量的类似于
?? 0
这样的代码! - 只修改一处无关紧要,一旦涉及到整个项目,可想而知有多么的蛋疼……
- 这里的 > 左右两边的操作数,必须是非可选类型!所以会出现大量的类似于
-
分析
- 出现这个问题的根本原因是 Swift3.0 后,运算符两边的操作数必须是非可选类型
- 我们可以重写比较运算符,让它接受可选类型的操作数,这样代码就不需要修改了!
☆ 重写运算符
public func > <T : Comparable>(lhs: T?, rhs: T?) -> Bool {
switch (lhs, rhs) {
case let (l?, r?):
return l > r
case (nil, _):
return false
case (_, nil):
return true
default:
return false
}
}
public func < <T : Comparable>(lhs: T?, rhs: T?) -> Bool {
return rhs > lhs
}
public func >= <T : Comparable>(lhs: T?, rhs: T?) -> Bool {
return lhs > rhs || lhs == rhs
}
public func <= <T : Comparable>(lhs: T?, rhs: T?) -> Bool {
return rhs >= lhs
}
这样就可以愉快地玩耍了,哈哈哈!
附录
Swift 标准库中的部分比较运算符
public func <(lhs: Int, rhs: Int) -> Bool
public func <=(lhs: Int, rhs: Int) -> Bool
public func >(lhs: Int, rhs: Int) -> Bool
public func >=(lhs: Int, rhs: Int) -> Bool
public func ==<T>(lhs: T?, rhs: T?) -> Bool where T : Equatable