我想参数化一些非常一般的类型参数的方法。斯卡拉类型:最小上界
作为一个例子,在REPL我首先定义:
trait Term
case class FunctionalTerm[+T <: Term](t: T) extends Term
直观地说,下面的方法以一个期限和一个FunctionalTerm,并返回一些与类型的最小上界通过术语的类型和FunctionalTerm的参数类型:
def ex1[T1 <: Term, T3 <: X, FunctionalTerm[T1] <: X, X <: R, R <: Term](t1: FunctionalTerm[T1], s: T3): R = sys.error("TODO")
到目前为止,在REPL中这么好。
然后我定义ex2
作为进行相同的操作,ex1
一个方便的功能,但与输入参数交换:
def ex2[T2 <: Term, T3 <: X, FunctionalTerm[T2] <: X, X <: R, R <: Term](s: T3, t2: FunctionalTerm[T2]): R = ex1(t2,s)
试图在REPL定义ex2
提供了以下错误:
error: inferred type arguments [T2,T3,FunctionalTerm,T3,T3] do not conform to method ex1's type parameter bounds [T1 <: Term,T3 <: X,FunctionalTerm[T1] <: X,X <: R,R <: Term]
ex1(t2,s)
^
error: type mismatch;
found : FunctionalTerm[T2]
required: FunctionalTerm[T1]
ex1(t2,s)
^
error: type mismatch;
found : T3(in method ex2)
required: T3(in method ex1)
ex1(t2,s)
^
error: type mismatch;
found : R(in method ex1)
required: R(in method ex2)
ex1(t2,s)
^
我花了大约两天的时间试图找出解决方案,现在我完全陷入困境。我无法在Google上找到更多内容。
由于ex2
类型参数列表相同的ex1
但T1
和T2
交换,我不明白的是错的,或如何解决它。
任何帮助将非常感激!
更新
最小上界是一个红色的鲱鱼。该示例可以进一步提炼。
以下两个功能可以在REPL中定义而不会出现错误:
def ex1[T1 <: Term, FunctionalTerm[T1] <: Term](t1: FunctionalTerm[T1]): Term = sys.error("TODO: ex1")
def ex2[T2 <: Term, FunctionalTerm[T2] <: Term](t2: FunctionalTerm[T2]): Term = ex1(t2)
介绍额外的参数X
似乎会导致问题。我可以定义在REPL如下:
def ex3[T1 <: Term, FunctionalTerm[T1] <: X, X <: Term](t1: FunctionalTerm[T1]): Term = sys.error("TODO: ex3")
但尝试之后定义:
def ex4[T2 <: Term, FunctionalTerm[T2] <: X, X <: Term](t2: FunctionalTerm[T2]): Term = ex3(t2)
给出了错误:
error: inferred type arguments [T2,FunctionalTerm,Nothing] do not conform to method ex3's type parameter bounds [T1 <: Term,FunctionalTerm[T1] <: X,X <: Term]
def ex4[T2 <: Term, FunctionalTerm[T2] <: X, X <: Term](t2: FunctionalTerm[T2]): Term = ex3(t2)
^
error: type mismatch;
found : FunctionalTerm[T2]
required: FunctionalTerm[T1]
def ex4[T2 <: Term, FunctionalTerm[T2] <: X, X <: Term](t2: FunctionalTerm[T2]): Term = ex3(t2)
^
所以,我想这个问题就变成了:为什么签名中未使用的参数X
是否具有此效果?
我忘了说,我使用Scala的2.10-M3。 –
虽然你没有使用更高的类型:-) –
@oxbow_lakes哦......我会更正 –