Scala隐式类型转换和==
发布时间:2020-12-16 19:12:14 所属栏目:安全 来源:网络整理
导读:任何人都可以告诉我为什么隐式类型转换不适用于==? 例: class BitArray(l: Int,v: Long) { val length = l var value = v def ==(that: BitArray) = value == that.value def ==(integer: Long) = value == integer def +(that: BitArray) = new BitArray(
任何人都可以告诉我为什么隐式类型转换不适用于==?
例: class BitArray(l: Int,v: Long) { val length = l var value = v def ==(that: BitArray) = value == that.value def ==(integer: Long) = value == integer def +(that: BitArray) = new BitArray(length,value+that.value ) def +(integer: Long) = new BitArray(length,value+integer ) //... } object BitArray{ implicit def longToBitArray(x : Long) = new BitArray(64,x) def apply(v: Long) :BitArray = apply(64,v) } 现在我能做到: scala> BitArray(5) + 5 res13: BitArray = 00000000000000000000000000001010 scala> 5 + BitArray(5) res14: BitArray = 00000000000000000000000000001010 scala> BitArray(5) == 5 res15: Boolean = true scala> BitArray(5) == 6 res16: Boolean = false 但: scala> 5 == BitArray(5) <console>:11: warning: comparing values of types Int and BitArray using `==' will always yield false 5 == BitArray(5) ^ res17: Boolean = false 解决方法
您缺少Scala的一个基本方面,即平等的工作方式.
基本上,所有扩展AnyRef的类都实现以下方法: def equals (arg0: Any) : Boolean 并且所有类都实现以下方法: def == (arg0: Any) : Boolean 现在,您应该覆盖非==,但等于.方法==将调用equals,但Java代码将使用equals,而不是==.这不是你看到的问题的原因,但重要的是我认为值得一提. 现在,关于隐式不工作,请记住只有在没有方法满足您的代码时才会查找implicits.但是,Int的==可以与BitArray进行比较,因为==接收类型为Any的参数.因此,调用Int的等式方法,并且不查找隐式方法. (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |