我知道如何自定义二进制运算符,像这样
infix operator ** { associativity left precedence 170 } func ** (left: Double,right: Double) -> Double { return pow(left,right) }
但是,如何在Swift中定制三元运算符?有人可以给我一些想法吗?非常感谢!
解决方法
您实际上可以通过声明两个独立的运算符来协同工作,并为其中一个运算符使用Curried函数.
让我们声明一个三元运算符x-y | – z,它将检查初始值x的符号,然后如果符号为零或正数则返回第二个值y,如果符号为负,则返回最终值z.也就是说,我们应该能够写:
let sign = -5 +- "non-negative" +|- "negative" // sign is now "negative"
我们首先宣布两个操作符.重要的部分是在第二个运算符上具有更高的优先级 – 我们首先评估该部分并返回一个函数:
infix operator +- { precedence 60 } infix operator +|- { precedence 70 }
func +|-<T>(lhs: @autoclosure () -> T,rhs: @autoclosure () -> T)(left: Bool) -> T { return left ? lhs() : rhs() }
这里的重要部分是这个函数是curried – 如果你只用前两个参数调用它,而不是返回一个T值,它返回一个(左:Bool) – > T功能.这成为我们第一个运算符函数的第二个参数:
func +-<I: SignedIntegerType,T>(lhs: I,rhs: (left: Bool) -> T) -> T { return rhs(left: lhs >= 0) }
现在我们可以使用我们的“三元”运算符,像这样:
for i in -1...1 { let sign = i +- "" +|- "-" println("\(i): '\(sign)'") } // -1: '-' // 0: '' // 1: ''
注意:我用另一个例子写了一个blog post on this subject.