जंग - स्मार्ट पॉइंटर्स

स्टैक डिफ़ॉल्ट रूप से स्टैक पर सब कुछ आवंटित करता है। आप बॉक्स जैसे स्मार्ट पॉइंटर्स में लपेटकर ढेर पर चीजों को स्टोर कर सकते हैं । वीईसी और स्ट्रिंग जैसे प्रकारों से स्पष्ट रूप से ढेर आवंटन में मदद मिलती है। स्मार्ट पॉइंटर्स नीचे दी गई तालिका में सूचीबद्ध लक्षणों को लागू करते हैं। स्मार्ट पॉइंटर्स के ये लक्षण उन्हें एक साधारण संरचना से अलग करते हैं -

अनु क्रमांक लक्षण नाम पैकेज और विवरण
1 Deref

std::ops::Deref

अपरिवर्तनीय डीरेफेरेंसिंग कार्यों के लिए उपयोग किया जाता है, जैसे * v।

2 ड्रॉप

std::ops::Drop

कुछ कोड चलाने के लिए उपयोग किया जाता है जब एक मान दायरे से बाहर चला जाता है। इसे कभी-कभी विध्वंसक भी कहा जाता है

इस अध्याय में, हम इसके बारे में जानेंगे Boxस्मार्ट सूचक। हम यह भी सीखेंगे कि बॉक्स जैसे कस्टम स्मार्ट पॉइंटर कैसे बनाएं।

डिब्बा

बॉक्स स्मार्ट पॉइंटर भी कहा जाता है एक बॉक्स आपको ढेर के बजाय ढेर पर डेटा स्टोर करने की अनुमति देता है। ढेर में ढेर डेटा के लिए सूचक होता है। एक बॉक्स में प्रदर्शन ओवरहेड नहीं होता है, जो ढेर पर अपना डेटा संग्रहीत करने के अलावा होता है।

आइए देखें कि ढेर पर i32 मान संग्रहीत करने के लिए बॉक्स का उपयोग कैसे करें।

fn main() {
   let var_i32 = 5; 
   //stack
   let b = Box::new(var_i32); 
   //heap
   println!("b = {}", b);
}

उत्पादन

b = 5

वैरिएबल द्वारा बताए गए मान को एक्सेस करने के लिए, डेरेफेरिंग का उपयोग करें। * का उपयोग एक डिरेक्शन ऑपरेटर के रूप में किया जाता है। आइए देखते हैं कि बॉक्स के साथ डीएफेरेंस का उपयोग कैसे करें।

fn main() {
   let x = 5; 
   //value type variable
   let y = Box::new(x); 
   //y points to a new value 5 in the heap

   println!("{}",5==x);
   println!("{}",5==*y); 
   //dereferencing y
}

चर x मान 5 के साथ एक मान-प्रकार है। इसलिए, अभिव्यक्ति 5 == x सही लौटेगी। चर y ढेर को इंगित करता है। हीप में मान को एक्सेस करने के लिए, हमें * y का उपयोग करके डीरेफेरेंस करने की आवश्यकता होती है * y रिटर्न मान 5. तो, अभिव्यक्ति 5 == * y सही है।

उत्पादन

true
true

चित्रण - डेरेफ़ ट्रेट

Deref विशेषता, मानक पुस्तकालय द्वारा प्रदान की जाती है, हमें deref नामक एक विधि को लागू करने की आवश्यकता होती है , जो स्वयं उधार लेती है और आंतरिक डेटा का संदर्भ देती है। निम्न उदाहरण एक संरचना MyBox बनाता है , जो एक सामान्य प्रकार है। यह विशेषता डेरेफ को लागू करता है । यह विशेषता हमें * y का उपयोग करके y द्वारा लिपटे ढेर मूल्यों तक पहुंचने में मदद करती है ।

use std::ops::Deref;
struct MyBox<T>(T);
impl<T> MyBox<T> { 
   // Generic structure with static method new
   fn new(x:T)-> MyBox<T> {
      MyBox(x)
   }
}
impl<T> Deref for MyBox<T> {
   type Target = T;
   fn deref(&self) -> &T {
      &self.0 //returns data
   }
}
fn main() {
   let x = 5;
   let y = MyBox::new(x); 
   // calling static method
   
   println!("5==x is {}",5==x);
   println!("5==*y is {}",5==*y); 
   // dereferencing y
   println!("x==*y is {}",x==*y);
   //dereferencing y
}

उत्पादन

5==x is true
5==*y is true
x==*y is true

चित्रण - ड्रॉप ट्रेट

ड्रॉप विशेषता में ड्रॉप () विधि है। इस पद्धति को तब कहा जाता है जब इस संरचना को लागू करने वाली संरचना कार्यक्षेत्र से बाहर हो जाती है। कुछ भाषाओं में, प्रोग्रामर को हर बार किसी स्मार्ट पॉइंटर के उदाहरण का उपयोग करके समाप्त होने वाली मेमोरी या संसाधनों को मुफ्त में कोड को कॉल करना होगा। रस्ट में, आप ड्रॉप विशेषता का उपयोग करके स्वचालित मेमोरी डीलक्लोशन प्राप्त कर सकते हैं।

use std::ops::Deref;

struct MyBox<T>(T);
impl<T> MyBox<T> {
   fn new(x:T)->MyBox<T>{
      MyBox(x)
   }
}
impl<T> Deref for MyBox<T> {
   type Target = T;
      fn deref(&self) -< &T {
      &self.0
   }
}
impl<T> Drop for MyBox<T>{
   fn drop(&mut self){
      println!("dropping MyBox object from memory ");
   }
}
fn main() {
   let x = 50;
   MyBox::new(x);
   MyBox::new("Hello");
}

उपरोक्त उदाहरण में, ड्रॉप विधि को दो बार कहा जाएगा क्योंकि हम ढेर में दो ऑब्जेक्ट बना रहे हैं।

dropping MyBox object from memory
dropping MyBox object from memory