मोनोमोर्फाइजेशन: Difference between revisions

From Vigyanwiki
No edit summary
 
Line 45: Line 45:
{{reflist}}
{{reflist}}


 
[[Category:CS1 English-language sources (en)]]
[[Category: बहुरूपता (कंप्यूटर विज्ञान)]]  
[[Category:CS1 errors]]
 
 
 
[[Category: Machine Translated Page]]
[[Category:Created On 16/06/2023]]
[[Category:Created On 16/06/2023]]
[[Category:Vigyan Ready]]
[[Category:Lua-based templates]]
[[Category:Machine Translated Page]]
[[Category:Pages with script errors]]
[[Category:Templates Vigyan Ready]]
[[Category:Templates that add a tracking category]]
[[Category:Templates that generate short descriptions]]
[[Category:Templates using TemplateData]]
[[Category:बहुरूपता (कंप्यूटर विज्ञान)]]

Latest revision as of 18:32, 3 July 2023

प्रोग्रामिंग भाषाओं में, मोनोमोर्फाइजेशन संकलन-समय की प्रक्रिया है इस प्रकार जहां बहुरूपी कार्यों को प्रत्येक अद्वितीय तात्कालिकता के लिए कई मोनोमोर्फिक कार्यों द्वारा प्रतिस्थापित किया जाता है।[1] उल्लिखित परिवर्तन से निकलने लाभदायक माना जाता है क्योंकि इसका परिणाम विशिष्ट प्रकार के आउटपुट इंटरमीडिएट प्रतिनिधित्व (आईआर) में होता है, तथा जो अधिक प्रभावी अनुकूलन की अनुमति देता है। और इसके अतिरिक्त, कई आईआर निम्न स्तर के होने का निश्चय रखते हैं और बहुरूपता को समायोजित नहीं करते हैं। जिससे परिणामी कोड सामान्यतः गतिशील प्रेषण से तेज़ होता है, किंतु फ़ंक्शन बॉडी को डुप्लिकेट करने के कारण अधिक संकलन समय और संग्रहण स्थान की आवश्यकता हो सकती है।[2][3][4][5][6][7]


उदाहरण

यह Rust_(programming_language) में जेनेरिक प्रोग्रामिंग पहचान फ़ंक्शन के उपयोग का उदाहरण है

fn id<T>(x: T) -> T {
    return x;
}

fn main() {
    let int = id(10);
    let string = id("some text");
    println!("{int}, {string}");
}

मोनोमोर्फाइजेशन के बाद, यह बन जाएगा

fn id_i32(x: i32) -> i32 {
    return x;
}

fn id_str(x: &str) -> &str {
    return x;
}

fn main() {
    let int = id_i32(10);
    let string = id_str("some text");
    println!("{int}, {string}");
}


यह भी देखें

संदर्भ

  1. "सामान्य डेटा प्रकार - जंग प्रोग्रामिंग भाषा". Retrieved 27 May 2021.
  2. Hume, Tristan. "Models of Generics and Metaprogramming: Go, Rust, Swift, D and More". Retrieved 27 May 2021.
  3. Tanaka, Akira; Affeldt, Reynald; Garrigue, Jacques (2018). "मोनोमोर्फाइजेशन और मोनाडिफिकेशन का उपयोग करके Coq में सुरक्षित निम्न-स्तरीय कोड जनरेशन". Journal of Information Processing. 26: 54–72. doi:10.2197/ipsjjip.26.54.
  4. "Extending Smt-Lib v2 with λ-Terms and Polymorphism". CiteSeerX 10.1.1.663.6849. {{cite journal}}: Cite journal requires |journal= (help)
  5. Cai, Yufei; Giarrusso, Paolo G.; Ostermann, Klaus (2016-01-11). "डेटाटाइप-जेनेरिक प्रोग्रामिंग के लिए समवर्ती प्रकार के साथ सिस्टम f-omega". Proceedings of the 43rd Annual ACM SIGPLAN-SIGACT Symposium on Principles of Programming Languages. POPL '16. St. Petersburg, FL, USA: Association for Computing Machinery: 30–43. doi:10.1145/2837614.2837660. ISBN 978-1-4503-3549-2. S2CID 17566568.
  6. Klabnik, Steve; Nichols, Carol (2019-08-06). The Rust Programming Language (Covers Rust 2018) (in English). No Starch Press. ISBN 978-1-7185-0044-0.
  7. Felty, Amy P.; Middeldorp, Aart (2015-07-30). Automated Deduction - CADE-25: 25th International Conference on Automated Deduction, Berlin, Germany, August 1-7, 2015, Proceedings (in English). Springer. ISBN 978-3-319-21401-6.