Swift 比较运算符

动机

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
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容