对组件的平等功能

时间:2013-12-11 09:33:08

标签: scala haskell tuples equality currying

Scala中是否有一个函数比较一对中的两个组件是否相等?类似的东西:

def pairEquals[A, B](pair: Pair[A, B]): Boolean = (pair._1 == pair._2)

在Haskell中,那将是:

uncurry (==)

1 个答案:

答案 0 :(得分:7)

标准库中没有类似的东西。但您可以轻松扩展Pairs以获得您的行为

implicit class PimpedTuple[A,B](tp: Tuple2[A,B]) {
  def pairEquals = tp._1 == tp._2
}

val x = (2, 3)
x.pairEquals  // false

val y = (1, 1)
y.pairEquals  // true

修改

另一种方法是:x == x.swap

<强> EDIT2:

这是第三种使用equals函数的方法,并使用与haskell中的uncurry类似的构造。

// This is necessary as there is no globally available function to compare values
def ===(a:Any, b: Any) = a == b

val x = (1,1)
(===_).tupled(x)   // true