Scala extra no-arg constructor plus default constructor parameters
I am using the Scala 2.8 default parameters on a constructor, and for Java compatibility reasons, I wanted a no-arg constructor that uses the default parameters.开发者_JAVA技巧
This doesn't work for very sensible reasons:
class MyClass(field1: String = "foo", field2: String = "bar") {
def this() = {
this() // <-- Does not compile, but how do I not duplicate the defaults?
}
}
I am wondering if there is anything that I am missing. Any thoughts that don't require duplicating the parameter defaults?
Thanks!
I wouldn't really recommend it, but you can do it by adding another parameter to your constructor:
class MyClass(a: String = "foo", b: String = "bar", u: Unit = ()) {
def this() { this(u = ()) }
}
Unit
is a good choice because you can only pass one thing into it anyway, so explicitly passing the default value doesn't allow any possibility of error, and yet it lets you call the correct constructor.
If you're willing to replicate just one of the defaults, you can use the same strategy except override that one chosen default instead of adding the unit parameter.
As curious work-around hack, and I do mean hack: you can use the internal representation of default arguments:
class MyClass(field1: String = "foo", field2: String = "bar") {
def this() = this(MyClass.init$default$1)
}
Notice that it's needed to include MyClass in this(MyClass.init$default$1). A partial explanation is that the default arguments are kept in companion objects.
You might consider using a factory method:
class MyClass(field1: String = "foo", field2: String = "bar")
object MyClass {
def newDefaultInstance = new MyClass
}
Then from Java you can call MyClass.newDefaultInstance()
Another possibility is to move where you specify the default values:
class MyClass(field1: String, field2: String) {
def this() = this(field1="foo", field2="bar")
}
This style is especially useful if you're working with a framework such as Spring which uses reflection to locate a 0-arg constructor.
Not suitable for all purposes, but a subclass might do the trick:
class DefaultMyClass extends MyClass()
If I am not wrong in understanding the question, following code worked very well for me`
class Employee (
){
def this( name :String ,
eid :Int ){
this();
}
}
`
精彩评论