Scala - कक्षाएं और वस्तुएँ

यह अध्याय आपको स्कैला प्रोग्रामिंग में कक्षाओं और वस्तुओं का उपयोग करने के माध्यम से ले जाता है। एक वर्ग वस्तुओं के लिए एक खाका है। एक बार जब आप एक क्लास को परिभाषित करते हैं, तो आप कीवर्ड के साथ क्लास ब्लूप्रिंट से ऑब्जेक्ट बना सकते हैंnew। ऑब्जेक्ट के माध्यम से आप परिभाषित वर्ग की सभी कार्यक्षमता का उपयोग कर सकते हैं।

निम्न आरेख कक्षा के छात्र का उदाहरण लेकर कक्षा और ऑब्जेक्ट को प्रदर्शित करता है, जिसमें सदस्य चर (नाम और रोल नंबर) और सदस्य विधियाँ (सेटनाम () और सेट रोलो ()) शामिल हैं। अंत में सभी वर्ग के सदस्य हैं। क्लास एक ब्लू प्रिंट है और ऑब्जेक्ट यहां असली हैं। निम्नलिखित आरेख में, छात्र एक वर्ग है और हारिनी, जॉन और मारिया छात्र वर्ग की वस्तुएं हैं, जिनका नाम और रोल-नंबर है।

बेसिक क्लास

स्काला में एक मूल वर्ग को परिभाषित करने के लिए एक सरल वाक्यविन्यास निम्नलिखित है। यह वर्ग दो चर को परिभाषित करता हैx तथा y और एक विधि: move, जो एक मूल्य वापस नहीं करता है। वर्ग चर कहलाते हैं, वर्ग के क्षेत्र और विधियों को वर्ग विधि कहा जाता है।

क्लास का नाम क्लास कंस्ट्रक्टर के रूप में काम करता है जो कई मापदंडों को ले सकता है। उपरोक्त कोड दो निर्माण तर्क को परिभाषित करता है,xc तथा yc; वे दोनों कक्षा के पूरे शरीर में दिखाई देते हैं।

वाक्य - विन्यास

class Point(xc: Int, yc: Int) {
   var x: Int = xc
   var y: Int = yc

   def move(dx: Int, dy: Int) {
      x = x + dx
      y = y + dy
      println ("Point x location : " + x);
      println ("Point y location : " + y);
   }
}

जैसा कि पहले इस अध्याय में बताया गया है, आप एक कीवर्ड का उपयोग करके ऑब्जेक्ट बना सकते हैं new और फिर आप वर्ग फ़ील्ड और विधियों का उपयोग कर सकते हैं जैसा कि उदाहरण में नीचे दिखाया गया है -

उदाहरण

import java.io._

class Point(val xc: Int, val yc: Int) {
   var x: Int = xc
   var y: Int = yc
   
   def move(dx: Int, dy: Int) {
      x = x + dx
      y = y + dy
      println ("Point x location : " + x);
      println ("Point y location : " + y);
   }
}

object Demo {
   def main(args: Array[String]) {
      val pt = new Point(10, 20);

      // Move to a new location
      pt.move(10, 10);
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Point x location : 20
Point y location : 30

एक वर्ग का विस्तार

आप एक बेस स्काला क्लास का विस्तार कर सकते हैं और आप उसी तरह से विरासत में मिला हुआ क्लास डिजाइन कर सकते हैं, जैसा कि आप इसे जावा में करते हैं extends कुंजी शब्द), लेकिन दो प्रतिबंध हैं: विधि को ओवरराइड करने की आवश्यकता होती है override कीवर्ड, और केवल primaryकंस्ट्रक्टर बेस कंस्ट्रक्टर को पैरामीटर पास कर सकता है। आइए हम अपने उपरोक्त वर्ग का विस्तार करें और एक और वर्ग विधि जोड़ें।

उदाहरण

आइए हम दो वर्गों का उदाहरण लेते हैं पॉइंट क्लास (ऊपर जैसा उदाहरण) और लोकेशन क्लास एक्सटेंडेड कीवर्ड का उपयोग करके विरासत में मिला वर्ग है। इस तरह के एक 'extends'खंड के दो प्रभाव हैं: यह स्थान वर्ग को सभी गैर-निजी सदस्यों को पॉइंट क्लास से इनहेरिट करता है, और यह टाइप लोकेशन को पॉइंट क्लास के प्रकार का उपप्रकार बनाता है । इसलिए यहां प्वाइंट क्लास कहा जाता हैsuperclassऔर वर्ग स्थान कहा जाता हैsubclass। एक वर्ग का विस्तार और एक मूल वर्ग की सभी विशेषताओं को विरासत में कहा जाता हैinheritance लेकिन स्काला केवल एक वर्ग से विरासत की अनुमति देता है।

Note - पॉइंट क्लास में मेथड्स मूव () मेथड और move() method in Location class चाल की संबंधित परिभाषाओं को ओवरराइड न करें क्योंकि वे अलग-अलग परिभाषाएं हैं (उदाहरण के लिए, पूर्व दो तर्क लेते हैं जबकि बाद वाले तीन तर्क देते हैं)।

विरासत को लागू करने के लिए निम्नलिखित उदाहरण कार्यक्रम का प्रयास करें।

import java.io._

class Point(val xc: Int, val yc: Int) {
   var x: Int = xc
   var y: Int = yc
   
   def move(dx: Int, dy: Int) {
      x = x + dx
      y = y + dy
      println ("Point x location : " + x);
      println ("Point y location : " + y);
   }
}

class Location(override val xc: Int, override val yc: Int,
   val zc :Int) extends Point(xc, yc){
   var z: Int = zc

   def move(dx: Int, dy: Int, dz: Int) {
      x = x + dx
      y = y + dy
      z = z + dz
      println ("Point x location : " + x);
      println ("Point y location : " + y);
      println ("Point z location : " + z);
   }
}

object Demo {
   def main(args: Array[String]) {
      val loc = new Location(10, 20, 15);

      // Move to a new location
      loc.move(10, 10, 5);
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Point x location : 20
Point y location : 30
Point z location : 20

इंप्लिमेंट क्लासेस

जब क्लास स्कोप में हो तो इम्प्लिमेंट क्लासेस क्लास के प्राइमरी कंस्ट्रक्टर के साथ निहित बातचीत की अनुमति देते हैं। इंप्लसिट क्लास एक वर्ग है जिसे 'निहित' कीवर्ड से चिह्नित किया जाता है। यह फीचर स्कैला 2.10 में पेश किया गया है।

Syntax- निम्नलिखित निहित वर्गों के लिए वाक्य रचना है। यहां निहित वर्ग हमेशा ऑब्जेक्ट स्कोप में होता है, जहां सभी विधि परिभाषाओं की अनुमति होती है क्योंकि निहित वर्ग एक शीर्ष स्तर वर्ग नहीं हो सकता है।

वाक्य - विन्यास

object <object name> {
   implicit class <class name>(<Variable>: Data type) {
      def <method>(): Unit =
   }
}

उदाहरण

आइए हम एक अंतर्निहित वर्ग का उदाहरण लेते हैं जिसका नाम है IntTimesविधि समय के साथ ()। इसका मतलब है कि समय () में एक लूप लेनदेन होता है जो दिए गए कथन को उस समय की संख्या में निष्पादित करेगा जो हम देते हैं। आइए मान लें कि दिया गया कथन "4 गुना प्रिंट्लन" ("हैलो") है। इसका मतलब है कि प्रिंटल ("हैलो") विवरण 4 बार निष्पादित होगा।

निम्नलिखित उदाहरण के लिए कार्यक्रम है। इस उदाहरण में दो ऑब्जेक्ट क्लास का उपयोग किया जाता है (रन और डेमो) ताकि हमें उन दो वर्गों को अलग-अलग फाइलों में उनके संबंधित नामों के साथ निम्नानुसार सहेजना पड़े।

Run.scala - Run.scala में निम्न प्रोग्राम सहेजें।

object Run {
   implicit class IntTimes(x: Int) {
      def times [A](f: =>A): Unit = {
         def loop(current: Int): Unit =
         
         if(current > 0){
            f
            loop(current - 1)
         }
         loop(x)
      }
   }
}

Demo.scala - Demo.scala में निम्न प्रोग्राम को सेव करें।

import Run._

object Demo {
   def main(args: Array[String]) {
      4 times println("hello")
   }
}

इन दो कार्यक्रमों को संकलित करने और निष्पादित करने के लिए निम्नलिखित कमांड का उपयोग किया जाता है।

आदेश

\>scalac Run.scala
\>scalac Demo.scala
\>scala Demo

उत्पादन

Hello
Hello
Hello
Hello

Note -

  • इंप्लसिव क्लासेस को दूसरे क्लास / ऑब्जेक्ट / ट्रेल (टॉप लेवल में नहीं) के अंदर परिभाषित किया जाना चाहिए।

  • निहित वर्ग अपने निर्माता में केवल एक ही गैर-तर्कपूर्ण तर्क ले सकते हैं।

  • निहित वर्गों के रूप में समान नाम के साथ किसी भी वर्ग, सदस्य या वस्तु के दायरे में कोई भी वर्ग नहीं हो सकता है।

सिंगलटन ऑब्जेक्ट्स

स्काला जावा की तुलना में अधिक ऑब्जेक्ट-ओरिएंटेड है क्योंकि स्काला में, हमारे पास स्थैतिक सदस्य नहीं हो सकते हैं। इसके बजाय, स्काला हैsingleton objects। एक सिंगलटन एक ऐसा वर्ग है जिसमें केवल एक उदाहरण हो सकता है, अर्थात, वस्तु। आप कीवर्ड का उपयोग करके सिंगलटन बनाते हैंobjectक्लास कीवर्ड के बजाय। चूंकि आप एक सिंगलटन ऑब्जेक्ट को इंस्टेंट नहीं कर सकते हैं, आप प्राथमिक कंस्ट्रक्टर को पैरामीटर पास नहीं कर सकते। आपने पहले से ही सभी उदाहरणों को सिंगलटन ऑब्जेक्ट्स का उपयोग करके देखा है, जहां आपको स्काला की मुख्य विधि कहा जाता है।

निम्नलिखित सिंगलटन को लागू करने के लिए एक ही उदाहरण कार्यक्रम है।

उदाहरण

import java.io._

class Point(val xc: Int, val yc: Int) {
   var x: Int = xc
   var y: Int = yc
   
   def move(dx: Int, dy: Int) {
      x = x + dx
      y = y + dy
   }
}

object Demo {
   def main(args: Array[String]) {
      val point = new Point(10, 20)
      printPoint

      def printPoint{
         println ("Point x location : " + point.x);
         println ("Point y location : " + point.y);
      }
   }
}

में उपरोक्त कार्यक्रम सहेजें Demo.scala। इस प्रोग्राम को संकलित करने और निष्पादित करने के लिए निम्न कमांड का उपयोग किया जाता है।

आदेश

\>scalac Demo.scala
\>scala Demo

उत्पादन

Point x location : 10
Point y location : 20