जंग - मॉड्यूल
कोड के एक तार्किक समूह को एक मॉड्यूल कहा जाता है। कई मॉड्यूल को एक इकाई में संकलित किया जाता हैcrate। जंग कार्यक्रमों में एक बाइनरी टोकरा या एक पुस्तकालय टोकरा हो सकता है। एक बाइनरी क्रेट एक निष्पादन योग्य परियोजना है जिसमें एक मुख्य () विधि है। एक पुस्तकालय टोकरा घटकों का एक समूह है जिसे अन्य परियोजनाओं में पुन: उपयोग किया जा सकता है। एक बाइनरी क्रेट के विपरीत, एक लाइब्रेरी क्रेट में एक प्रवेश बिंदु (मुख्य () विधि) नहीं है। कार्गो टूल का उपयोग रस्ट में बक्से को प्रबंधित करने के लिए किया जाता है। उदाहरण के लिए, नेटवर्क मॉड्यूल में नेटवर्क से संबंधित फ़ंक्शन होते हैं और ग्राफिक्स मॉड्यूल में ड्राइंग-संबंधित फ़ंक्शन होते हैं। मॉड्यूल अन्य प्रोग्रामिंग भाषाओं में नामस्थान के समान हैं। थर्ड-पार्टी क्रेट को crates.io से कार्गो का उपयोग करके डाउनलोड किया जा सकता है ।
अनु क्रमांक | शब्द और विवरण |
---|---|
1 | crate जंग में एक संकलन इकाई है; क्रेट को बाइनरी या लाइब्रेरी के लिए संकलित किया गया है। |
2 | cargo टोकरा के लिए आधिकारिक जंग पैकेज प्रबंधन उपकरण। |
3 | module तार्किक रूप से समूह एक टोकरा के भीतर कोड। |
4 | crates.io आधिकारिक जंग पैकेज रजिस्ट्री। |
वाक्य - विन्यास
//public module
pub mod a_public_module {
pub fn a_public_function() {
//public function
}
fn a_private_function() {
//private function
}
}
//private module
mod a_private_module {
fn a_private_function() {
}
}
मॉड्यूल सार्वजनिक या निजी हो सकते हैं। एक निजी मॉड्यूल में घटकों को अन्य मॉड्यूल द्वारा एक्सेस नहीं किया जा सकता है। डिफ़ॉल्ट रूप से जंग में मॉड्यूल निजी हैं। इसके विपरीत, एक सार्वजनिक मॉड्यूल में कार्यों को अन्य मॉड्यूल द्वारा एक्सेस किया जा सकता है। मॉड्यूल के साथ उपसर्ग किया जाना चाहिएpubकीवर्ड इसे सार्वजनिक करने के लिए। सार्वजनिक मॉड्यूल के भीतर कार्य को भी सार्वजनिक किया जाना चाहिए।
चित्रण: एक मॉड्यूल को परिभाषित करना
उदाहरण एक सार्वजनिक मॉड्यूल को परिभाषित करता है - फिल्में । मॉड्यूल में एक फ़ंक्शन प्ले () होता है जो एक पैरामीटर को स्वीकार करता है और इसके मूल्य को प्रिंट करता है।
pub mod movies {
pub fn play(name:String) {
println!("Playing movie {}",name);
}
}
fn main(){
movies::play("Herold and Kumar".to_string());
}
उत्पादन
Playing movie Herold and Kumar
कीवर्ड का उपयोग करें
उपयोग कीवर्ड एक सार्वजनिक मॉड्यूल आयात करने के लिए मदद करता है।
वाक्य - विन्यास
use public_module_name::function_name;
चित्रण
pub mod movies {
pub fn play(name:String) {
println!("Playing movie {}",name);
}
}
use movies::play;
fn main(){
play("Herold and Kumar ".to_string());
}
उत्पादन
Playing movie Herold and Kumar
नेस्टेड मॉड्यूल
मॉड्यूल भी घोंसले के शिकार हो सकते हैं। कॉमेडी मॉड्यूल के भीतर नीडिंत है अंग्रेज़ी मॉड्यूल है, जो आगे में नीडिंत है फिल्में मॉड्यूल। नीचे दिया गया उदाहरण फिल्मों / अंग्रेजी / कॉमेडी मॉड्यूल के अंदर एक फंक्शन प्ले को परिभाषित करता है ।
pub mod movies {
pub mod english {
pub mod comedy {
pub fn play(name:String) {
println!("Playing comedy movie {}",name);
}
}
}
}
use movies::english::comedy::play;
// importing a public module
fn main() {
// short path syntax
play("Herold and Kumar".to_string());
play("The Hangover".to_string());
//full path syntax
movies::english::comedy::play("Airplane!".to_string());
}
उत्पादन
Playing comedy movie Herold and Kumar
Playing comedy movie The Hangover
Playing comedy movie Airplane!
चित्रण - एक लाइब्रेरी क्रेट बनाएं और एक बाइनरी क्रेट में उपभोग करें
आइए नाम से एक लाइब्रेरी क्रेट बनाएं movie_lib, जिसमें एक मॉड्यूल होता है movies। बनाने के लिएmovie_lib पुस्तकालय टोकरा, हम उपकरण का उपयोग करेंगे cargo।
चरण 1 - प्रोजेक्ट फ़ोल्डर बनाएँ
एक फोल्डर मूवी-ऐप बनाएं, उसके बाद सब-फोल्डर मूवी-लिब । फ़ोल्डर और उप-फ़ोल्डर बनाए जाने के बाद, एक बनाएंsrcइस डायरेक्टरी में फोल्डर और एक कार्गो.टोमल फाइल। स्रोत कोड को src फ़ोल्डर में जाना चाहिए । Src फ़ोल्डर में lib.rs और movies.rs फ़ाइल बनाएँ। Cargo.toml फ़ाइल संस्करण संख्या, लेखक का नाम, आदि जैसे परियोजना के मेटाडाटा में शामिल होंगे
परियोजना निर्देशिका संरचना निम्नानुसार दिखाई जाएगी -
movie-app
movie-lib/
-->Cargo.toml
-->src/
lib.rs
movies.rs
चरण 2 - प्रोजेक्ट मेटाडेटा जोड़ने के लिए Cargo.toml फ़ाइल को संपादित करें
[package]
name = "movies_lib"
version = "0.1.0"
authors = ["Mohtashim"]
चरण 3 - lib.rs फ़ाइल को संपादित करें।
इस फ़ाइल में निम्न मॉड्यूल परिभाषा जोड़ें।
pub mod movies;
उपरोक्त लाइन एक सार्वजनिक मॉड्यूल बनाती है - movies।
चरण 4 - movies.rs फ़ाइल को संपादित करें
यह फ़ाइल मूवी मॉड्यूल के लिए सभी फ़ंक्शन को परिभाषित करेगी।
pub fn play(name:String){
println!("Playing movie {} :movies-app",name);
}
उपरोक्त कोड एक फ़ंक्शन को परिभाषित करता है play() यह एक पैरामीटर को स्वीकार करता है और इसे कंसोल पर प्रिंट करता है।
चरण 5 - पुस्तकालय टोकरा बनाएँ
का उपयोग कर एप्लिकेशन बनाएँ cargo buildयह सत्यापित करने के लिए कि लाइब्रेरी टोकरा ठीक से संरचित है या नहीं। सुनिश्चित करें कि आप परियोजना के मूल में हैं - मूवी-ऐप फ़ोल्डर। बिल्ड के सफल होने पर निम्न संदेश टर्मिनल में प्रदर्शित होगा।
D:\Rust\movie-lib> cargo build
Compiling movies_lib v0.1.0 (file:///D:/Rust/movie-lib)
Finished dev [unoptimized + debuginfo] target(s) in 0.67s
चरण 6 - एक परीक्षण एप्लिकेशन बनाएं
एक और फ़ोल्डर बनाएँ movie-lib-testकार्गो-फ़ाइल और src फ़ोल्डर के बाद मूवी-ऐप फ़ोल्डर में। इस परियोजना में मुख्य विधि होनी चाहिए क्योंकि यह एक द्विआधारी टोकरा है, जो पहले बनाए गए पुस्तकालय टोकरे का उपभोग करेगा। Src फ़ोल्डर में एक main.rs फ़ाइल बनाएँ। फ़ोल्डर संरचना के रूप में दिखाया जाएगा।
movie-app
movie-lib
// already completed
movie-lib-test/
-->Cargo.toml
-->src/
main.rs
चरण Step - कार्गो.टॉम फाइल में निम्नलिखित जोड़ें
[package]
name = "test_for_movie_lib"
version = "0.1.0"
authors = ["Mohtashim"]
[dependencies]
movies_lib = { path = "../movie-lib" }
NOTE- लाइब्रेरी फ़ोल्डर का मार्ग निर्भरता के रूप में सेट किया गया है। निम्नलिखित आरेख दोनों परियोजनाओं की सामग्री को दर्शाता है।
चरण 8 - निम्नलिखित को main.rs फ़ाइल में जोड़ें
extern crate movies_lib;
use movies_lib::movies::play;
fn main() {
println!("inside main of test ");
play("Tutorialspoint".to_string())
}
उपरोक्त कोड मूवीज_लिब नामक एक बाहरी पैकेज का आयात करता है। टोकरा नाम सत्यापित करने के लिए वर्तमान परियोजना के Cargo.toml की जाँच करें।
चरण 9 - कार्गो बिल्ड और कार्गो रन का उपयोग
हम बाइनरी प्रोजेक्ट के निर्माण के लिए कार्गो बिल्ड और कार्गो रन का उपयोग करेंगे और इसे नीचे दिखाए अनुसार निष्पादित करेंगे -