जंग - एनम

रस्ट प्रोग्रामिंग में, जब हमें संभावित वेरिएंट की सूची से एक मूल्य का चयन करना होता है तो हम एन्यूमरेशन डेटा प्रकारों का उपयोग करते हैं। Enumerated type को enum keyword का उपयोग करके घोषित किया जाता है । एनुम का वाक्य विन्यास निम्नलिखित है -

enum enum_name {
   variant1,
   variant2,
   variant3
}

चित्रण: एक गणना का उपयोग करना

उदाहरण एक Enum की घोषणा करता है - GenderCategory , जिसमें पुरुष और महिला के रूप में भिन्न रूप हैं। प्रिंट! मैक्रो एनम का मान प्रदर्शित करता है। कंपाइलर एक त्रुटि को ट्रेट स्टैड में फेंक देगा :: fmt :: डीबग को GenderCategory के लिए लागू नहीं किया जाता है । इस त्रुटि को दबाने के लिए विशेषता # [व्युत्पन्न (डीबग)] का उपयोग किया जाता है।

// The `derive` attribute automatically creates the implementation
// required to make this `enum` printable with `fmt::Debug`.
#[derive(Debug)]
enum GenderCategory {
   Male,Female
}
fn main() {
   let male = GenderCategory::Male;
   let female = GenderCategory::Female;

   println!("{:?}",male);
   println!("{:?}",female);
}

उत्पादन

Male
Female

संरचना और Enum

निम्न उदाहरण एक व्यक्ति को संरचना को परिभाषित करता है। फ़ील्ड लिंग , प्रकार GenderCategory (जो एक एनम है) का होता है और इसे या तो पुरुष या महिला को मान के रूप में सौंपा जा सकता है ।

// The `derive` attribute automatically creates the 
implementation
// required to make this `enum` printable with 
`fmt::Debug`.

#[derive(Debug)]
enum GenderCategory {
   Male,Female
}

// The `derive` attribute automatically creates the implementation
// required to make this `struct` printable with `fmt::Debug`.
#[derive(Debug)]
struct Person {
   name:String,
   gender:GenderCategory
}

fn main() {
   let p1 = Person {
      name:String::from("Mohtashim"),
      gender:GenderCategory::Male
   };
   let p2 = Person {
      name:String::from("Amy"),
      gender:GenderCategory::Female
   };
   println!("{:?}",p1);
   println!("{:?}",p2);
}

उदाहरण प्रकार के व्यक्ति के ऑब्जेक्ट p1 और P2 बनाता है और इनमें से प्रत्येक ऑब्जेक्ट के लिए विशेषताओं, नाम और लिंग को इनिशियलाइज़ करता है।

उत्पादन

Person { name: "Mohtashim", gender: Male }
Person { name: "Amy", gender: Female }

विकल्प Enum

विकल्प रुस्ट मानक पुस्तकालय में पूर्वनिर्धारित एनम है। इस एनम के दो मूल्य हैं - कुछ (डेटा) और कोई नहीं।

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

enum Option<T> {
   Some(T),      //used to return a value
   None          // used to return null, as Rust doesn't support 
   the null keyword
}

यहाँ, T टाइप किसी भी प्रकार का मान दर्शाता है।

जंग अशक्त कीवर्ड का समर्थन नहीं करता है । मूल्य कोई नहीं , में enumOption , एक समारोह से इस्तेमाल किया जा सकता एक अशक्त मान देने के लिए। यदि लौटने के लिए डेटा है, तो फ़ंक्शन कुछ (डेटा) वापस कर सकता है ।

आइए इसे एक उदाहरण से समझते हैं -

कार्यक्रम एक प्रकार को परिभाषित करता है एक वापसी प्रकार विकल्प के साथ, is_even () । फ़ंक्शन सत्यापित करता है कि मान दिया गया मान एक सम संख्या है। यदि इनपुट समान है, तो एक मान सच लौटाया जाता है, और फ़ंक्शन कोई भी नहीं लौटाता है ।

fn main() {
   let result = is_even(3);
   println!("{:?}",result);
   println!("{:?}",is_even(30));
}
fn is_even(no:i32)->Option<bool> {
   if no%2 == 0 {
      Some(true)
   } else {
      None
   }
}

उत्पादन

None
Some(true)

मैच स्टेटमेंट और एनम

मैच बयान एक enum में संग्रहीत मूल्यों की तुलना करने के लिए इस्तेमाल किया जा सकता है। निम्न उदाहरण एक फ़ंक्शन को परिभाषित करता है, Print_size , जो पैरामीटर के रूप में CarType Enum लेता है । फ़ंक्शन स्थिरांक के पूर्व-निर्धारित सेट के साथ पैरामीटर मानों की तुलना करता है और उपयुक्त संदेश प्रदर्शित करता है।

enum CarType {
   Hatch,
   Sedan,
   SUV
}
fn print_size(car:CarType) {
   match car {
      CarType::Hatch => {
         println!("Small sized car");
      },
      CarType::Sedan => {
         println!("medium sized car");
      },
      CarType::SUV =>{
         println!("Large sized Sports Utility car");
      }
   }
}
fn main(){
   print_size(CarType::SUV);
   print_size(CarType::Hatch);
   print_size(CarType::Sedan);
}

उत्पादन

Large sized Sports Utility car
Small sized car
medium sized car

विकल्प के साथ मिलान करें

Is_even फ़ंक्शन का उदाहरण , जो विकल्प प्रकार देता है, नीचे दिए गए विवरण के साथ मैच स्टेटमेंट के साथ भी लागू किया जा सकता है -

fn main() {
   match is_even(5) {
      Some(data) => {
         if data==true {
            println!("Even no");
         }
      },
      None => {
         println!("not even");
      }
   }
}
fn is_even(no:i32)->Option<bool> {
   if no%2 == 0 {
      Some(true)
   } else {
      None
   }
}

उत्पादन

not even

डेटा प्रकार के साथ मैच और एनम

एक एनम के प्रत्येक संस्करण में डेटा प्रकार जोड़ना संभव है। निम्नलिखित उदाहरण में, enum के नाम और Usr_ID संस्करण क्रमशः स्ट्रिंग और पूर्णांक प्रकार के हैं। निम्न उदाहरण एक डेटा प्रकार वाले एनम के साथ मैच स्टेटमेंट के उपयोग को दर्शाता है।

// The `derive` attribute automatically creates the implementation
// required to make this `enum` printable with `fmt::Debug`.
#[derive(Debug)]
enum GenderCategory {
   Name(String),Usr_ID(i32)
}
fn main() {
   let p1 = GenderCategory::Name(String::from("Mohtashim"));
   let p2 = GenderCategory::Usr_ID(100);
   println!("{:?}",p1);
   println!("{:?}",p2);

   match p1 {
      GenderCategory::Name(val)=> {
         println!("{}",val);
      }
      GenderCategory::Usr_ID(val)=> {
         println!("{}",val);
      }
   }
}

उत्पादन

Name("Mohtashim")
Usr_ID(100)
Mohtashim