gpt4 book ai didi

scala - 如何从 TypeClass 解析中排除特定类型?

转载 作者:行者123 更新时间:2023-12-02 07:59:29 25 4
gpt4 key购买 nike

我想为大多数类型提供一个 ToCondition 操作,但不为字符串提供。 (这是在移植 Javascript 代码时,经常进行非空和非零测试,重写所有此类测试以进行适当比较非常乏味)。这样做很容易,因此我会在运行时收到错误消息:

trait ToCondition[T] {
def apply(x: T): Boolean
}
implicit object ToConditionInt extends ToCondition[Int] {
override def apply(x: Int) = x != 0
}
implicit object ToConditionString extends ToCondition[String] {
override def apply(x: String) = throw new UnsupportedOperationException("Cannot use String as a condition")
}
implicit object ToConditionAnyRef extends ToCondition[AnyRef] {
override def apply(x: AnyRef) = x != null
}

def toCondition[T: ToCondition](a: T): Boolean = implicitly[ToCondition[T]].apply(a)

toCondition(1) // true

toCondition(null:AnyRef) // false

toCondition("") // throws runtime

能否以某种方式表达此约束,以便我在编译时得到错误?

最佳答案

您可以将广义类型约束与永远不会为真的条件一起使用,例如String =:= Nothing:

implicit def ToConditionString(implicit ev: String =:= Nothing) = new ToCondition[String] {
override def apply(x: String) = throw new UnsupportedOperationException("Cannot use String as a condition")
}

然后

toCondition("")

编译时失败:

could not find implicit value for evidence parameter of type ToCondition[String]

关于scala - 如何从 TypeClass 解析中排除特定类型?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/59355722/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com