जंग - स्वामित्व

एक कार्यक्रम के लिए मेमोरी निम्नलिखित में आवंटित की जा सकती है -

  • Stack
  • Heap

ढेर

एक स्टैक पहले आउट ऑर्डर में एक अंतिम का अनुसरण करता है। स्टैक डेटा मूल्यों को संग्रहीत करता है जिसके लिए आकार को संकलन समय पर जाना जाता है। उदाहरण के लिए, स्थिर आकार i32 का एक चर ढेर आवंटन के लिए एक उम्मीदवार है। इसका आकार संकलन समय पर जाना जाता है। सभी स्केलर प्रकारों को स्टैक में संग्रहीत किया जा सकता है क्योंकि आकार तय हो गया है।

एक स्ट्रिंग के उदाहरण पर विचार करें, जिसे रनटाइम पर एक मान सौंपा गया है। इस तरह के तार का सटीक आकार संकलन समय पर निर्धारित नहीं किया जा सकता है। तो यह स्टैक आवंटन के लिए एक उम्मीदवार नहीं है लेकिन ढेर आवंटन के लिए है।

ढेर

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

स्वामित्व क्या है?

रस्ट के प्रत्येक मान में एक चर होता है जिसे कहा जाता है ownerमूल्य का। रस्ट में संग्रहीत प्रत्येक डेटा के साथ एक मालिक जुड़ा होगा। उदाहरण के लिए, वाक्यविन्यास में - आयु ३० = मान ३० वर्ष का है

  • प्रत्येक डेटा में एक बार में केवल एक ही स्वामी हो सकता है।

  • दो चर एक ही मेमोरी लोकेशन की ओर इशारा नहीं कर सकते। चर हमेशा अलग-अलग मेमोरी स्थानों की ओर इशारा करेंगे।

स्वामित्व हस्तांतरित करना

मूल्य के स्वामित्व को इसके द्वारा स्थानांतरित किया जा सकता है -

  • एक चर का दूसरे चर पर मान देना।

  • फ़ंक्शन के लिए पासिंग मान।

  • किसी फ़ंक्शन से मान वापस करना।

एक चर का दूसरे चर पर मान देना

एक भाषा के रूप में रस्ट का प्रमुख विक्रय बिंदु इसकी मेमोरी सुरक्षा है। स्मृति सुरक्षा तंग नियंत्रण द्वारा प्राप्त की जाती है जो प्रतिबंधों का उपयोग कब और क्या कर सकता है।

निम्नलिखित स्निपेट पर विचार करें -

fn main(){
   let v = vec![1,2,3]; 
   // vector v owns the object in heap

   //only a single variable owns the heap memory at any given time
   let v2 = v; 
   // here two variables owns heap value,
   //two pointers to the same content is not allowed in rust

   //Rust is very smart in terms of memory access ,so it detects a race condition
   //as two variables point to same heap

   println!("{:?}",v);
}

उपरोक्त उदाहरण एक वेक्टर v घोषित करता है। स्वामित्व का विचार यह है कि केवल एक चर एक संसाधन को बांधता है, या तो v संसाधन के लिए बांधता है या v2संसाधन के लिए बाध्य करता है। ऊपर दिए गए उदाहरण में एक त्रुटि है - स्थानांतरित मूल्य का उपयोग: `v` । ऐसा इसलिए है क्योंकि संसाधन का स्वामित्व v2 में स्थानांतरित किया गया है। इसका मतलब है कि स्वामित्व को v से v2 (v2 = v) में स्थानांतरित कर दिया गया है और v को स्थानांतरित करने के बाद अमान्य कर दिया गया है।

फ़ंक्शन के लिए पासिंग मान

एक मूल्य का स्वामित्व भी बदल जाता है जब हम ढेर में किसी वस्तु को बंद करने या कार्य करने के लिए पास करते हैं।

fn main(){
   let v = vec![1,2,3];     // vector v owns the object in heap
   let v2 = v;              // moves ownership to v2
   display(v2);             // v2 is moved to display and v2 is invalidated
   println!("In main {:?}",v2);    //v2 is No longer usable here
}
fn display(v:Vec<i32>){
   println!("inside display {:?}",v);
}

किसी फ़ंक्शन से मान वापस करना

फ़ंक्शन के पास दिया गया स्वामित्व फ़ंक्शन निष्पादन पूर्ण होने पर अमान्य हो जाएगा। इसके लिए एक काम यह है कि फ़ंक्शन कॉल करने वाले को वापस स्वामित्व वाली वस्तु लौटा दे।

fn main(){
   let v = vec![1,2,3];       // vector v owns the object in heap
   let v2 = v;                // moves ownership to v2
   let v2_return = display(v2);    
   println!("In main {:?}",v2_return);
}
fn display(v:Vec<i32>)->Vec<i32> { 
   // returning same vector
   println!("inside display {:?}",v);
}

स्वामित्व और आदिम प्रकार

आदिम प्रकारों के मामले में, एक चर से सामग्री दूसरे में कॉपी की जाती है। इसलिए, कोई स्वामित्व नहीं हो रहा है। ऐसा इसलिए है क्योंकि एक आदिम चर को किसी वस्तु की तुलना में कम संसाधनों की आवश्यकता होती है। निम्नलिखित उदाहरण पर विचार करें -

fn main(){
   let u1 = 10;
   let u2 = u1;  // u1 value copied(not moved) to u2

   println!("u1 = {}",u1);
}

आउटपुट होगा - 10।