scala - 如何定义与更高种类类型绑定(bind)的上下文(类型构造函数)

标签 scala generics types higher-kinded-types context-bound

我试过以下方法

def test[Option[T]: Ordering](value1: Option[T], value2: Option[T]) = {
  val e = implicitly(Ordering[Option[T]].compare(value1, value2))
}

但不起作用?知道问题出在哪里吗?

编辑

这当然有效

def test[T](value1: Option[T], value2: Option[T]) (implicit ev: Ordering[Option[T]]) = {
  ev.compare(value1, value2)
}

最佳答案

如果你真的坚持使用上下文绑定(bind),你可以写一个 lambda 类型:

def test[T: ({type L[x] = Ordering[Option[x]]})#L](value1: Option[T], value2: Option[T]) = {
  val e = implicitly(Ordering[Option[T]].compare(value1, value2))
}

或使用 kind-projector插件你应该能够让它更干净一点:

def test[T: Lambda[x => Ordering[Option[x]]]](value1: Option[T], value2: Option[T]) = {
  val e = implicitly(Ordering[Option[T]].compare(value1, value2))
}

关于scala - 如何定义与更高种类类型绑定(bind)的上下文(类型构造函数),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63922959/

相关文章:

scala - Akka Actor 选择

斯卡拉 2.13,SBT : sbt compile uses wrong compiler version

scala - 在 Spark-Scala 中将 Dataset[Row] 转换为 RDD[Array[String]] 的最佳方法?

swift - 在 Swift 中有条件地将协议(protocol)提升为泛型类型

css - 警告 : CSS type selectors are not supported in components 'sparks.component.TextInput'

ruby - 如何从可能具有前导零的字符串中解析数字?

scala - 从 Scala 解析器组合器中过滤标记

java - 尝试获取泛型类型参数时出现 ClassCastException

c# - 将数值具体类型转换为数值泛型

c# - 使用 C# 在 asp.net 中排序列表和下拉列表