How to override a mutable variable in Trait in scala?

10,529

Solution 1

You cannot override it (for reasons that don't reveal themselves to me right now, except, that vars can be modified anyway so why override them), but you can leave the declared variable uninitialised and delegate the latter to B:

trait A {
  var a: Int
}

class B(var a: Int) extends A

Solution 2

Overriding is only for methods. It doesn't make sense to override a variable. What changes if you override a variable with another variable of the same type? If anything, the value and that can just be set anytime anyway, because it is a variable:

trait A { 
  var a: Int = _ 
}

class B (a0: Int) extends A {
  a = a0
}

But that is propably not what you want. You may also just leave the getter and setter abstract:

trait A {
  def a: Int
  def a_=(value: Int): Unit
}

class B(var a: Int)

which is then equivalent to

trait A {
  var a: Int
}

Solution 3

try use val instead of var and use override. It work when A is abstract class, Like this:

abstract class A{
  val a:Int = 0
}

class B extends A{
override val a:Int=1
}

Solution 4

Note exactly sure what you would want to achieve with an attempt to "override" a "var" which as others have mentioned you can change anyways.

Among many other guesses, one is that you would want something like self type members? where self type annotation allows you to access members of a mixin trait or class, and Scala compiler ensures that all the dependencies are correctly wired? If so, something like following will work.

trait B{
var a:Int = _

}

trait A{self:B=> var b= a}
class C extends A with B
Share:
10,529

Related videos on Youtube

zjffdu
Author by

zjffdu

Committer of Pig/Tez/Livy/Zeppelin at The Apache Software Foundation

Updated on September 15, 2022

Comments

  • zjffdu
    zjffdu over 1 year

    I'd like override one mutable variable in Trait in constructor. But it will complain that "overriding variable a in trait A of type Int; variable a cannot override a mutable variable". Why the scala do not allow me do that ? And any best practise for this ? Thanks

    trait A{
      var a:Int = _
    }
    
    class B(override var a:Int) extends A
    
  • Shaun Ryan
    Shaun Ryan about 4 years
    I think.. am learning myself. It's to do with details around how it autogens setters and getters & efficiency in the compiler. But yeah am not sure why you would override it other than to deliberately duplicate code.