डार्ट प्रोग्रामिंग - कक्षाएं

डार्ट एक ऑब्जेक्ट-ओरिएंटेड भाषा है। यह क्लास, इंटरफेस, आदि जैसे ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग सुविधाओं का समर्थन करता हैclassOOP के संदर्भ में वस्तुओं को बनाने का एक खाका है। एclassऑब्जेक्ट के लिए डेटा इनकैप्सुलेट करता है। डार्ट नामक इस अवधारणा के लिए अंतर्निहित समर्थन देता हैclass

एक वर्ग की घोषणा

उपयोग class एक की घोषणा करने के लिए कीवर्ड classडार्ट में। कीवर्ड वर्ग के बाद एक वर्ग परिभाषा शुरू होती हैclass name; और घुंघराले ब्रेसिज़ की एक जोड़ी द्वारा संलग्न वर्ग शरीर। उसी का सिंटैक्स नीचे दिया गया है -

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

class class_name {  
   <fields> 
   <getters/setters> 
   <constructors> 
   <functions> 
}

classकीवर्ड का वर्ग नाम के बाद अनुसरण किया जाता है। कक्षा का नामकरण करते समय पहचानकर्ताओं के नियमों पर विचार किया जाना चाहिए।

एक वर्ग परिभाषा में निम्नलिखित शामिल हो सकते हैं -

  • Fields- एक क्षेत्र किसी भी वर्ग में घोषित चर है। फ़ील्ड ऑब्जेक्ट से संबंधित डेटा का प्रतिनिधित्व करती हैं।

  • Setters and Getters- कार्यक्रम को एक वर्ग के क्षेत्रों के मूल्यों को शुरू करने और पुनः प्राप्त करने की अनुमति देता है। एक डिफ़ॉल्ट गेटटर / सेटर हर वर्ग के साथ जुड़ा हुआ है। हालाँकि, डिफ़ॉल्ट रूप से एक सेटर / गेट्टर को स्पष्ट रूप से परिभाषित करके ओवरराइड किया जा सकता है।

  • Constructors - कक्षा की वस्तुओं के लिए स्मृति आवंटित करने के लिए जिम्मेदार।

  • Functions- कार्य उन क्रियाओं का प्रतिनिधित्व करते हैं जो एक वस्तु ले सकती है। उन्हें कई बार विधियों के रूप में भी जाना जाता है।

इन घटकों को एक साथ रखा जाता है data members वर्ग का।

उदाहरण: एक वर्ग की घोषणा

class Car {  
   // field 
   String engine = "E1001";  
   
   // function 
   void disp() { 
      print(engine); 
   } 
}

उदाहरण एक वर्ग घोषित करता है Car। वर्ग का एक क्षेत्र है जिसका नाम हैenginedisp() एक साधारण कार्य है जो क्षेत्र के मूल्य को प्रिंट करता है engine

कक्षा का उदाहरण बनाना

कक्षा का एक उदाहरण बनाने के लिए, का उपयोग करें newकीवर्ड के बाद वर्ग नाम। उसी का सिंटैक्स नीचे दिया गया है -

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

var object_name = new class_name([ arguments ])
  • new तत्काल के लिए कीवर्ड जिम्मेदार है।

  • अभिव्यक्ति का दाहिना हाथ निर्माणकर्ता को आमंत्रित करता है। यदि इसे मानकीकृत किया जाता है, तो कंस्ट्रक्टर को मान दिया जाना चाहिए।

उदाहरण: एक वर्ग को त्वरित करना

var obj = new Car("Engine 1")

पहुँच गुण और कार्य

एक कक्षा के गुण और कार्यों को ऑब्जेक्ट के माध्यम से एक्सेस किया जा सकता है। उपयोग '।' डॉट संकेतन (के रूप में कहा जाता हैperiod) एक वर्ग के डेटा सदस्यों तक पहुँचने के लिए।

//accessing an attribute 
obj.field_name  

//accessing a function 
obj.function_name()

उदाहरण

डार्ट में विशेषताओं और कार्यों का उपयोग करने के तरीके को समझने के लिए निम्नलिखित उदाहरण पर एक नज़र डालें -

void main() { 
   Car c= new Car(); 
   c.disp(); 
}  
class Car {  
   // field 
   String engine = "E1001";  
   
   // function 
   void disp() { 
      print(engine); 
   } 
}

output उपरोक्त कोड इस प्रकार है -

E1001

डार्ट कंस्ट्रक्टर्स

एक रचनाकार वर्ग का एक विशेष कार्य है जो कक्षा के चर को आरंभ करने के लिए जिम्मेदार है। Dart एक रचनाकार को उसी नाम से परिभाषित करता है जैसे वह वर्ग है। एक कंस्ट्रक्टर एक फ़ंक्शन है और इसलिए इसे पैरामीटर किया जा सकता है। हालाँकि, फ़ंक्शन के विपरीत, कंस्ट्रक्टरों के पास रिटर्न प्रकार नहीं हो सकता है। यदि आप एक निर्माता, एक डिफ़ॉल्ट घोषित नहीं करते हैंno-argument constructor आपके लिए प्रदान किया गया है।

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

Class_name(parameter_list) { 
   //constructor body 
}

उदाहरण

निम्न उदाहरण से पता चलता है कि डार्ट में निर्माणकर्ताओं का उपयोग कैसे किया जाता है -

void main() { 
   Car c = new Car('E1001'); 
} 
class Car { 
   Car(String engine) { 
      print(engine); 
   } 
}

यह निम्नलिखित उत्पादन करना चाहिए output -

E1001

जिसका नाम कंस्ट्रक्टर्स रखा गया है

डार्ट प्रदान करता है named constructors एक वर्ग को परिभाषित करने के लिए multiple constructors। नामित निर्माणकर्ताओं का सिंटैक्स नीचे दिया गया है -

सिंटेक्स: कंस्ट्रक्टर को परिभाषित करना

Class_name.constructor_name(param_list)

उदाहरण

निम्न उदाहरण दिखाता है कि आप डार्ट में नामित कंस्ट्रक्टरों का उपयोग कैसे कर सकते हैं -

void main() {           
   Car c1 = new Car.namedConst('E1001');                                       
   Car c2 = new Car(); 
}           
class Car {                   
   Car() {                           
      print("Non-parameterized constructor invoked");
   }                                   
   Car.namedConst(String engine) { 
      print("The engine is : ${engine}");    
   }                               
}

यह निम्नलिखित उत्पादन करना चाहिए output -

The engine is : E1001 
Non-parameterized constructor invoked

इस खोजशब्द

thisकीवर्ड क्लास के वर्तमान उदाहरण को संदर्भित करता है। यहां, पैरामीटर नाम और वर्ग के क्षेत्र का नाम समान हैं। इसलिए अस्पष्टता से बचने के लिए, वर्ग के क्षेत्र के साथ उपसर्ग किया जाता हैthisकीवर्ड। निम्नलिखित उदाहरण वही बताते हैं -

उदाहरण

निम्नलिखित उदाहरण बताते हैं कि कैसे उपयोग करना है this Dart में कीवर्ड -

void main() { 
   Car c1 = new Car('E1001'); 
}  
class Car { 
   String engine; 
   Car(String engine) { 
      this.engine = engine; 
      print("The engine is : ${engine}"); 
   } 
}

यह निम्नलिखित उत्पादन करना चाहिए output -

The engine is : E1001

डार्ट क्लास art गेटर्स एंड सेटर्स

Getters तथा Settersभी कहा जाता है accessors तथा mutators, प्रोग्राम को क्रमशः क्लास फ़ील्ड्स के मानों को शुरू करने और पुनः प्राप्त करने की अनुमति देता है। गेटर्स या एक्सेसर्स का उपयोग करके परिभाषित किया गया हैgetकीवर्ड। सेटर्स या म्यूटेटर का उपयोग करके परिभाषित किया गया हैset कीवर्ड।

एक डिफ़ॉल्ट गेटटर / सेटर हर वर्ग के साथ जुड़ा हुआ है। हालाँकि, डिफ़ॉल्ट रूप से एक सेटर / गेट्टर को स्पष्ट रूप से परिभाषित करके ओवरराइड किया जा सकता है। एक गेटर के पास कोई पैरामीटर नहीं है और एक मान लौटाता है, और सेटर के पास एक पैरामीटर है और एक मान नहीं लौटाता है।

सिंटेक्स: एक गटर को परिभाषित करना

Return_type  get identifier 
{ 
}

सिंटैक्स: एक सेटर को परिभाषित करना

set identifier 
{ 
}

उदाहरण

निम्न उदाहरण दिखाता है कि आप कैसे उपयोग कर सकते हैं getters तथा setters एक डार्ट क्लास में -

class Student { 
   String name; 
   int age; 
    
   String get stud_name { 
      return name; 
   } 
    
   void set stud_name(String name) { 
      this.name = name; 
   } 
   
   void set stud_age(int age) { 
      if(age<= 0) { 
        print("Age should be greater than 5"); 
      }  else { 
         this.age = age; 
      } 
   } 
   
   int get stud_age { 
      return age;     
   } 
}  
void main() { 
   Student s1 = new Student(); 
   s1.stud_name = 'MARK'; 
   s1.stud_age = 0; 
   print(s1.stud_name); 
   print(s1.stud_age); 
}

यह प्रोग्राम कोड निम्नलिखित उत्पादन करना चाहिए output -

Age should be greater than 5 
MARK 
Null

कक्षा में प्रवेश

डार्ट इनहेरिटेंस की अवधारणा का समर्थन करता है जो एक मौजूदा कक्षा से नई कक्षाएं बनाने के लिए एक कार्यक्रम की क्षमता है। नए वर्ग बनाने के लिए जिस वर्ग का विस्तार किया जाता है, उसे मूल वर्ग / सुपर क्लास कहा जाता है। नव निर्मित कक्षाओं को बच्चे / उप कक्षाएं कहा जाता है।

एक वर्ग 'एक्सटेंड्स' कीवर्ड का उपयोग करके दूसरे वर्ग से विरासत में मिला है। Child classes inherit all properties and methods except constructors from the parent class

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

class child_class_name extends parent_class_name

Note - डार्ट एकाधिक वंशानुक्रम का समर्थन नहीं करता है।

उदाहरण: क्लास इनहेरिटेंस

निम्नलिखित उदाहरण में, हम एक वर्ग घोषित कर रहे हैं Shape। वर्ग द्वारा बढ़ाया जाता हैCircleकक्षा। चूंकि कक्षाओं, बाल वर्ग, यानी वर्ग के बीच एक अंतर्निहित संबंध हैCar अपने मूल वर्ग डेटा सदस्य के लिए एक अंतर्निहित पहुँच प्राप्त करता है।

void main() { 
   var obj = new Circle(); 
   obj.cal_area(); 
}  
class Shape { 
   void cal_area() { 
      print("calling calc area defined in the Shape class"); 
   } 
}  
class Circle extends Shape {}

यह निम्नलिखित उत्पादन करना चाहिए output -

calling calc area defined in the Shape class

वंशानुक्रम के प्रकार

वंशानुक्रम निम्नलिखित तीन प्रकार के हो सकते हैं -

  • Single - प्रत्येक वर्ग एक मूल वर्ग से सबसे अधिक विस्तार कर सकता है।

  • Multiple- एक वर्ग कई वर्गों से वारिस हो सकता है। डार्ट एकाधिक वंशानुक्रम का समर्थन नहीं करता है।

  • Multi-level - एक वर्ग दूसरे बाल वर्ग से विरासत में मिल सकता है।

उदाहरण

निम्न उदाहरण दिखाता है कि बहु-स्तरीय विरासत कैसे काम करती है -

void main() { 
   var obj = new Leaf(); 
   obj.str = "hello"; 
   print(obj.str); 
}  
class Root { 
   String str; 
}  
class Child extends Root {}  
class Leaf extends Child {}  
//indirectly inherits from Root by virtue of inheritance

कक्षा Leafमल्टी लेवल इनहेरिटेंस के आधार पर रूट और चाइल्ड क्लासेस की विशेषताओं को प्राप्त करता है। आईटी इसoutput इस प्रकार है -

hello

डार्ट - क्लास इनहेरिटेंस और मेथड ओवरराइडिंग

मेथड ओवरराइडिंग एक ऐसा तंत्र है जिसके द्वारा बच्चा वर्ग अपने मूल वर्ग में एक विधि को फिर से परिभाषित करता है। निम्न उदाहरण से पता चलता है -

उदाहरण

void main() { 
   Child c = new Child(); 
   c.m1(12); 
} 
class Parent { 
   void m1(int a){ print("value of a ${a}");} 
}  
class Child extends Parent { 
   @override 
   void m1(int b) { 
      print("value of b ${b}"); 
   } 
}

यह निम्नलिखित उत्पादन करना चाहिए output -

value of b 12

विधि को ओवरराइड करते समय फ़ंक्शन मापदंडों की संख्या और प्रकार को मेल खाना चाहिए। मापदंडों या उनके डेटा प्रकार की संख्या में एक बेमेल के मामले में, डार्ट संकलक एक त्रुटि फेंकता है। निम्नलिखित दृष्टांत वही बताते हैं -

import 'dart:io'; 
void main() { 
   Child c = new Child(); 
   c.m1(12); 
} 
class Parent { 
   void m1(int a){ print("value of a ${a}");} 
} 
class Child extends Parent { 
   @override 
   void m1(String b) { 
      print("value of b ${b}");
   } 
}

यह निम्नलिखित उत्पादन करना चाहिए output -

value of b 12

स्थैतिक खोजशब्द

static कीवर्ड को किसी वर्ग के डेटा सदस्यों के लिए लागू किया जा सकता है, अर्थात, fields तथा methods। एक स्थिर चर कार्यक्रम के निष्पादन को पूरा करने तक अपने मूल्यों को बरकरार रखता है। स्टैटिक सदस्यों को वर्ग नाम से संदर्भित किया जाता है।

उदाहरण

class StaticMem { 
   static int num;  
   static disp() { 
      print("The value of num is ${StaticMem.num}")  ; 
   } 
}  
void main() { 
   StaticMem.num = 12;  
   // initialize the static variable } 
   StaticMem.disp();   
   // invoke the static method 
}

यह निम्नलिखित उत्पादन करना चाहिए output -

The value of num is 12

सुपर कीवर्ड

superकीवर्ड का उपयोग किसी वर्ग के तत्काल माता-पिता को संदर्भित करने के लिए किया जाता है। कीवर्ड का उपयोग सुपर वर्ग संस्करण के संदर्भ में किया जा सकता हैvariable, property, या method। निम्न उदाहरण से पता चलता है -

उदाहरण

void main() { 
   Child c = new Child(); 
   c.m1(12); 
} 
class Parent { 
   String msg = "message variable from the parent class"; 
   void m1(int a){ print("value of a ${a}");} 
} 
class Child extends Parent { 
   @override 
   void m1(int b) { 
      print("value of b ${b}"); 
      super.m1(13); 
      print("${super.msg}")   ; 
   } 
}

यह निम्नलिखित उत्पादन करना चाहिए output -

value of b 12 
value of a 13 
message variable from the parent class