加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 综合聚焦 > 服务器 > 安全 > 正文

在scala中trait中使用的抽象值有什么问题吗?

发布时间:2020-12-16 09:47:24 所属栏目:安全 来源:网络整理
导读:我有 trait Invoker { val method: Method} Intellij IDEA代码检查警告我“抽象值用于trait”。一切编译良好。在trait中有一个抽象的值有什么问题吗?如果是这样,我应该如何指定trait的所有扩展器必须定义一个方法属性? 解决方法 这是什么意思是以下奇怪:
我有

trait Invoker {
  val method: Method
}

Intellij IDEA代码检查警告我“抽象值用于trait”。一切编译良好。在trait中有一个抽象的值有什么问题吗?如果是这样,我应该如何指定trait的所有扩展器必须定义一个方法属性?

解决方法

这是什么意思是以下奇怪:

trait A {
  val i: String
  def j: String
}

class C extends A {
  println ("val i = " + i)
  println ("def j = " + j)

  val i = "i"
  def j = "j"
}

val c = new C
// prints
// val i = null
// def j = j

所以,你可以看到,我被初始化为它的默认值(AnyRef的null),它最终被C中的构造函数覆盖。(def声明立即重新引用。

为了避免这种情况,如果可能的话,必须把val初始化到构造函数的开头。

在下面的情况下额外的奇怪(和如何解决它)

考虑

trait A {
  val i: String
  def j: String
}

abstract class D extends A {
  println ("val i = " + i)
  println ("def j = " + j)
}

class C extends D {
  val i = "i"
  def j = "j"
}
val c = new C
// prints
// val i = null
// def j = null

现在我们似乎失去了运气;它看起来好像没有机会,我们在我们的超类D尝试打印它们之前初始化val i和def j。
为了解决这个问题,我们必须使用Early定义(§5.1.6Scala reference):

class C extends {
  val i = "i"
  def j = "j"
} with D

val c = new C
// prints
// val i = i
// def j = j

它的工作原理!

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读