父母特质的Scala隐式转换
发布时间:2020-12-16 09:14:47 所属栏目:安全 来源:网络整理
导读:以下代码不编译: import scala.language.implicitConversionstrait Base { class Wrp[+T](val v: T) // wrapper / internal representation}trait BooleanOps extends Base { // implicit conversion implicit def lift2BooleanOpsCls(x: Boolean): Boolean
以下代码不编译:
import scala.language.implicitConversions trait Base { class Wrp[+T](val v: T) // wrapper / internal representation } trait BooleanOps extends Base { // implicit conversion implicit def lift2BooleanOpsCls(x: Boolean): BooleanOpsCls = new BooleanOpsCls(new Wrp[Boolean](x)) class BooleanOpsCls(wx: Wrp[Boolean]) { def ||(wy: =>Wrp[Boolean]): Wrp[Boolean] = new Wrp[Boolean](wx.v || wy.v) } } trait MyExample extends BooleanOps { // test method def foo(): Wrp[Boolean] = { val ret: Wrp[Boolean] = false || new Wrp[Boolean](true) ret } } 输出: MyExample.scala:18: error: type mismatch; found : MyExample.this.Wrp[Boolean] required: Boolean val ret: Wrp[Boolean] = false || new Wrp[Boolean](true) ^ 但如果我: 1)把类Wrp放在Base之外 要么 2)将BooleanOps的主体移动到MyExample 一切编译 为什么原来的例子不行?如果您对此行为有一些了解,将不胜感激.谢谢. 解决方法
一个问题是def ||(wy:=> Wrp [Boolean])中的参数的按名称性质,
如果你rewite它def ||(wy:Wrp [Boolean])它的工作 但我同意,如果您移动Wrp或BooleanOpsCls,它是有用的,这是奇怪的!隐含分辨率的意图或错误? (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |