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