Swift 比较运算符

版权声明:本文为原创文章,未经博主允许不得转载,有问题欢迎讨论。 https://blog.csdn.net/u014696025/article/details/77527752

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

猜你喜欢

转载自blog.csdn.net/u014696025/article/details/77527752