在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。 class C extends { val i = "i" def j = "j" } with D val c = new C // prints // val i = i // def j = j 它的工作原理! (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |