স্কালায় আপনি কীভাবে ওভারলোডেড কনস্ট্রাক্টর সরবরাহ করবেন?
স্কালায় আপনি কীভাবে ওভারলোডেড কনস্ট্রাক্টর সরবরাহ করবেন?
উত্তর:
এটি স্পষ্টভাবে উল্লেখ করার মতো যে, স্কালায় সহায়তাকারী কনস্ট্রাক্টরকে তাদের প্রথম ক্রিয়া হিসাবে প্রাথমিক কন্সট্রাক্টরকে (ল্যান্ডন9720 এর মতো) উত্তর বা একই শ্রেণীর অন্য সহায়ক কন্সট্রাক্টরকে কল করতে হবে। তারা জাভাতে যেমন সুপারক্লাসের নির্মাতাকে স্পষ্টভাবে বা স্পষ্টভাবে কল করতে পারে না। এটি নিশ্চিত করে যে প্রাথমিক নির্মাতা ক্লাসে প্রবেশের একমাত্র পয়েন্ট।
class Foo(x: Int, y: Int, z: String) {
// default y parameter to 0
def this(x: Int, z: String) = this(x, 0, z)
// default x & y parameters to 0
// calls previous auxiliary constructor which calls the primary constructor
def this(z: String) = this(0, z);
}
new
এমনকি কেস ক্লাসের জন্য কীওয়ার্ডটি প্রয়োজনীয়।
class Foo(x: Int, y: Int) {
def this(x: Int) = this(x, 0) // default y parameter to 0
}
স্কেলা ২.৮.০ অনুসারে আপনার কনট্রাক্টর এবং পদ্ধতি পরামিতিগুলির জন্য ডিফল্ট মান থাকতে পারে। এটার মত
scala> class Foo(x:Int, y:Int = 0, z:Int=0) {
| override def toString() = { "Foo(" + x + ", " + y + ", " + z + ")" }
| }
defined class Foo
scala> new Foo(1, 2, 3)
res0: Foo = Foo(1, 2, 3)
scala> new Foo(4)
res1: Foo = Foo(4, 0, 0)
প্যারামিটার তালিকায় কোনও ডিফল্ট মান না থাকলে ডিফল্ট মানগুলির সাথে পরামিতিগুলি অবশ্যই আসতে হবে।
class Foo(val x:Int, y:Int=2*x)
কাজ করে না।
new Foo(x=2,z=4)
মুদ্রণ করবে Foo(2,0,4)
।
আমার কোডটি দেখার সময় আমি হঠাৎ বুঝতে পারি যে আমি কোনও নির্মাণকারীর ওভারলোডের মতো কাজ করেছি। আমি তখন সেই প্রশ্নটির কথা মনে রেখে আবার ফিরে এসেছি:
স্কালায় আপনি কনস্ট্রাক্টরদের ওভারলোড করতে পারবেন না, তবে আপনি এটি ফাংশন দিয়ে করতে পারেন।
এছাড়াও, অনেকে apply
সঙ্গীর কাজটিকে সংশ্লিষ্ট শ্রেণীর জন্য একটি কারখানা তৈরির উদ্দেশ্যে পছন্দ করে ।
এই শ্রেণীর বিমূর্ততা তৈরি করা এবং এই ক্লাসটি apply
বাস্তবায়ন-ইনস্ট্যান্ট করার জন্য ফাংশনটি ওভারলোড করা, আপনার নিজের ওভারলোডড "কনস্ট্রাক্টর" রয়েছে:
abstract class Expectation[T] extends BooleanStatement {
val expected: Seq[T]
…
}
object Expectation {
def apply[T](expd: T ): Expectation[T] = new Expectation[T] {val expected = List(expd)}
def apply[T](expd: Seq[T]): Expectation[T] = new Expectation[T] {val expected = expd }
def main(args: Array[String]): Unit = {
val expectTrueness = Expectation(true)
…
}
}
নোট করুন যে আমি প্রত্যেকে apply
প্রত্যাবর্তনের জন্য স্পষ্টভাবে সংজ্ঞায়িত করেছি Expectation[T]
, অন্যথায় এটি হাঁসের মতো টাইপ করবে Expectation[T]{val expected: List[T]}
।
এটা চেষ্টা কর
class A(x: Int, y: Int) {
def this(x: Int) = this(x, x)
def this() = this(1)
override def toString() = "x=" + x + " y=" + y
class B(a: Int, b: Int, c: String) {
def this(str: String) = this(x, y, str)
override def toString() =
"x=" + x + " y=" + y + " a=" + a + " b=" + b + " c=" + c
}
}
new Foo(x=2,z=4)
এবংnew Foo(z=5)
যদি আপনি আপনার প্রথম লাইন পরিবর্তনclass Foo(x: Int = 0, y: Int = 0, z: String) {