我想要一个高阶函数Function[K=>V, K=>V]
,它接受一个函数K=>V
并返回给定函数的类型。例如,我希望有以下行为:
class Foo[K, V]() {
def apply[K1 <: K, V1 <: V](f: K1 => V1) = f
}
// dummy class hierachy
class A
class B extends A
class C extends B
// a function f: B=>B
def f(some: B): B = some
// the desired result
val result1: B => B = new Foo[A, A]()(f)
apply 方法Foo
接受 aB=>B
并返回 a B=>B
。类型参数K
和V
跟踪“最高”类型Foo
可以作为参数。现在,我想Foo
扩展功能
class Bar[K, V] extends Function[K=>V, K=>V]() {
def apply(f: K => V) = f
}
val result2: B => B = new Bar[A, A]()(f)
但这显然不起作用。有没有办法使这项工作?谢谢
编辑
class Fuzz[K, V, K1 <: K, V1 <: V] extends Function[K1=>V1, K1=>V1] {
def apply(f: K1 => V1) = f
}
val result3: B => B = new Fuzz[A, A, B, B]()(f)
也可以,但是我不想携带两个额外的类型参数