7

假设我有以下代码:

class Bar { def bar(b:Bar):Boolean = true }
def func(b:Bar) = b.bar(b)    

以上工作正常。该类Bar是在第 3 方库中定义的,并且有几个类似的类,每个类都有一个bar方法,例如

class Foo { def bar(f:Foo):Boolean = false }

func我不想为每个此类编写,而是想func使用泛型类型进行定义B ,只要它具有bar正确签名的方法即可。

我尝试了以下方法,但它给了我一个错误:

def func[B <: {def bar(a:B):Boolean}](b:B) = b.bar(b) // gives error

我得到的错误是:

<console>:16: error: Parameter type in structural refinement may not refer to 
an abstract type defined outside that refinement
def func[B <: {def bar(a:B):Boolean}](b:B) = b.bar(b)
                       ^

但是,如果我执行以下操作,则方法定义有效,但调用会出错:

def func[B <: {def bar(a:Any):Boolean}](b:B) = b.bar(b)

func(new Bar) 

<console>:10: error: type mismatch;
found   : Bar
required: B
          func(new Bar)
               ^

有什么方法可以在不更改代码的情况下做我想做的事Bar吗?

4

1 回答 1

2

方法参数的结构类型之外定义的抽象类型的问题就足够了。其次,您的方法不起作用,因为方法签名不相等(看起来像方法重载)。

我建议使用解决方法。方法定义的函数方法,因为 Function1[-T1, +R] 是已知类型:

class Bar { def bar : Bar => Boolean = _ => true }
class Foo { def bar : Foo => Boolean = _ => false }

def func[T <: { def bar : T => Boolean } ](b: T): Boolean = b.bar(b)

func(new Bar)
func(new Foo) 

缺点和优点功能类型VS方法类型定义在这里

于 2014-04-09T11:16:26.547 回答