मेमोरी पूल: Difference between revisions

From Vigyanwiki
(Created page with "{{Short description|Dynamic memory allocation method}} {{No footnotes|date=June 2014}} मेमोरी पूल, जिसे निश्चित आकार के...")
 
No edit summary
 
(7 intermediate revisions by 4 users not shown)
Line 1: Line 1:
{{Short description|Dynamic memory allocation method}}
{{Short description|Dynamic memory allocation method}}'''मेमोरी पूल''', जिसे [[निश्चित आकार के ब्लॉक आवंटन|निश्चित आकृति के ब्लॉक एलोकेशन]] भी कहा जाता है, मेमोरी प्रबंधन के लिए [[पूल (कंप्यूटर विज्ञान)|पूल]] का उपयोग होता है जो [[गतिशील स्मृति आवंटन|डायनमिक मेमोरी एलोकेशन]] की अनुमति देता है। गतिशील मेमोरी एलोकेशन [[मॉलोक]] और [[सी++]] के [[ नया (सी++) |नवीन]] जैसी तकनीकों के उपयोग से प्राप्त किया जा सकता है और किया भी गया है; यघपि स्थापित और विश्वसनीय कार्यान्वयन, ये परिवर्तनीय ब्लॉक आकृतियों के कारण [[विखंडन (कंप्यूटर)|विखंडन]] से घीरे होते हैं, प्रदर्शन के कारण इन्हें [[वास्तविक समय कंप्यूटिंग|रियल टाइम सिस्टम]] में उपयोग करने की अनुशंसा नहीं की जाती है। अधिक कुशल समाधान समान आकृति वाले विभिन्न मेमोरी ब्लॉकों को पूर्व-एलोकेशन करना होता है जिन्हें '''मेमोरी पूल''' कहा जाता है। एप्लिकेशन रन टाइम (प्रोग्राम जीवनचक्र चरण) पर [[हैंडल (कंप्यूटिंग)|हैंडल]] द्वारा प्रदर्शित किये गए ब्लॉकों को आवंटित, अभिगम और मुक्त कर सकता है।
{{No footnotes|date=June 2014}}


मेमोरी पूल, जिसे [[निश्चित आकार के ब्लॉक आवंटन]] भी कहा जाता है, मेमोरी प्रबंधन के लिए [[पूल (कंप्यूटर विज्ञान)]] का उपयोग है जो [[गतिशील स्मृति आवंटन]] की अनुमति देता है। गतिशील मेमोरी आवंटन [[मॉलोक]] और [[सी++]] के [[ नया (सी++) ]] जैसी तकनीकों के उपयोग से हासिल किया जा सकता है और किया गया है; हालांकि स्थापित और विश्वसनीय कार्यान्वयन, ये परिवर्तनीय ब्लॉक आकारों के कारण [[विखंडन (कंप्यूटर)]] से ग्रस्त हैं, प्रदर्शन के कारण इन्हें [[वास्तविक समय कंप्यूटिंग]] में उपयोग करने की अनुशंसा नहीं की जाती है। एक अधिक कुशल समाधान समान आकार वाले कई मेमोरी ब्लॉकों को पूर्व-आबंटित करना है जिन्हें मेमोरी पूल कहा जाता है। एप्लिकेशन रन टाइम (प्रोग्राम जीवनचक्र चरण) पर [[हैंडल (कंप्यूटिंग)]] द्वारा दर्शाए गए ब्लॉकों को आवंटित, एक्सेस और मुक्त कर सकता है।
कई रियल-टाइम ऑपरेटिंग सिस्टम मेमोरी पूल का उपयोग करते हैं, जैसे [[लेनदेन प्रसंस्करण सुविधा|विनिमय प्रसंस्करण सुविधा]]


कई RTOS#मेमोरी एलोकेशन|रियल-टाइम ऑपरेटिंग सिस्टम मेमोरी पूल का उपयोग करते हैं, जैसे [[लेनदेन प्रसंस्करण सुविधा]]
कुछ प्रणालियाँ, जैसे वेब सर्वर [[Nginx|एनजीआईएनएक्स]], चर-आकृति एलोकेशन के समूह को संदर्भित करने के लिए ''मेमोरी पूल'' शब्द का उपयोग करती हैं, जिन्हें पश्चात् में एक ही बार में हटाया जा सकता है। इसे एक ''क्षेत्र'' के नाम से भी जाना जाता है; क्षेत्र-आधारित [[स्मृति प्रबंधन|मेमोरी प्रबंधन]] देखें।
 
कुछ प्रणालियाँ, जैसे वेब सर्वर [[Nginx]], चर-आकार आवंटन के एक समूह को संदर्भित करने के लिए ''मेमोरी पूल'' शब्द का उपयोग करती हैं, जिन्हें बाद में एक ही बार में हटाया जा सकता है। इसे ''क्षेत्र'' के नाम से भी जाना जाता है; क्षेत्र-आधारित [[स्मृति प्रबंधन]] देखें.


== सरल मेमोरी पूल कार्यान्वयन ==
== सरल मेमोरी पूल कार्यान्वयन ==
एक साधारण मेमोरी पूल मॉड्यूल, उदाहरण के लिए, मॉड्यूल को तैनात करने वाले एप्लिकेशन के लिए अनुकूलित ब्लॉक आकार के साथ [[संकलन समय]] पर तीन पूल आवंटित कर सकता है। एप्लिकेशन निम्नलिखित इंटरफ़ेस के माध्यम से मेमोरी आवंटित, एक्सेस और मुक्त कर सकता है:
साधारण मेमोरी पूल मॉड्यूल, उदाहरण के लिए, मॉड्यूल को स्थापित करने वाले एप्लिकेशन के लिए अनुकूलित ब्लॉक आकृति के साथ [[संकलन समय|कंपाइल समय]] पर तीन पूल निर्धारित कर सकता है। एप्लिकेशन निम्नलिखित इंटरफ़ेस के माध्यम से मेमोरी एलोकेशन, अभिग्म और मुक्त कर सकता है:


*पूल से स्मृति आवंटित करें। फ़ंक्शन उस पूल का निर्धारण करेगा जहां आवश्यक ब्लॉक फिट बैठता है। यदि उस पूल के सभी ब्लॉक पहले से ही आरक्षित हैं, तो फ़ंक्शन अगले बड़े पूल में से एक को खोजने का प्रयास करता है। एक आवंटित मेमोरी ब्लॉक को एक हैंडल (कंप्यूटिंग) के साथ दर्शाया जाता है।
*पूल से मेमोरी एलोकेशन करें। फ़ंक्शन उस पूल का निर्धारण करेगा जहां आवश्यक ब्लॉक उपयुक्त स्थित होता है। यदि उस पूल के सभी ब्लॉक पहले से ही आरक्षित होते हैं, तो फ़ंक्शन अगले बड़े पूल में से को अन्वेषण का प्रयास करता है। एलोटेड मेमोरी ब्लॉक को हैंडल के साथ प्रदर्शित किया जाता है।
* आवंटित मेमोरी तक पहुंच सूचक प्राप्त करें।
* आवंटित मेमोरी तक अभिग्म सूचक प्राप्त करें।
*पूर्व में आवंटित मेमोरी ब्लॉक को मुक्त करें।
*पूर्व में एलोटेड मेमोरी ब्लॉक को मुक्त करें।
*उदाहरण के लिए हैंडल को एक के साथ कार्यान्वित किया जा सकता है <code>unsigned int</code>. मॉड्यूल हैंडल को पूल इंडेक्स, मेमोरी ब्लॉक इंडेक्स और एक संस्करण में विभाजित करके आंतरिक रूप से व्याख्या कर सकता है। पूल और मेमोरी ब्लॉक इंडेक्स हैंडल के साथ संबंधित ब्लॉक तक तेजी से पहुंच की अनुमति देता है, जबकि संस्करण, जो प्रत्येक नए आवंटन पर बढ़ाया जाता है, उन हैंडल का पता लगाने की अनुमति देता है जिनका मेमोरी ब्लॉक पहले ही मुक्त हो चुका है (बहुत लंबे समय तक रखे गए हैंडल के कारण)।
*उदाहरण के लिए हैंडल को के साथ कार्यान्वित किया जा सकता है। मॉड्यूल हैंडल को पूल क्रम-सूची, मेमोरी ब्लॉक क्रम-सूची और संस्करण में विभाजित करके आंतरिक रूप से व्याख्या कर सकता है। पूल और मेमोरी ब्लॉक क्रम-सूची हैंडल के साथ संबंधित ब्लॉक तक शीघ्रता से अभिग्म की अनुमति देता है, जबकि संस्करण, जो प्रत्येक नए एलोकेशन पर बढ़ाया जाता है, उन हैंडल का पता लगाने की अनुमति देता है जिनका मेमोरी ब्लॉक पहले ही मुक्त हो चुकी होती है (बहुत लंबे समय तक रखे गए हैंडल के कारण)।


== मेमोरी पूल बनाम मॉलोक ==
== मेमोरी पूल विरुद्ध मॉलोक ==
फ़ायदे
लाभ
*मेमोरी पूल निरंतर निष्पादन समय के साथ मेमोरी आवंटन की अनुमति देता है। यदि प्रत्येक ऑब्जेक्ट के लिए मेमोरी आवंटित करने के लिए ''मॉलोक'' का उपयोग किया जाता है, तो पूल में हजारों ऑब्जेक्ट के लिए मेमोरी रिलीज़ केवल एक ऑपरेशन है, एक-एक करके नहीं।
*मेमोरी पूल निरंतर निष्पादन समय के साथ मेमोरी एलोकेशन की अनुमति देता है। यदि प्रत्येक वस्तु के लिए मेमोरी आवंटित करने के लिए ''मॉलोक'' का उपयोग किया जाता है, तो पूल में हजारों वस्तुओं के लिए मेमोरी रिलीज़ मात्र एक संचाल होता है, नाकि एक- एक करके होता है।
*मेमोरी पूल को पदानुक्रमित वृक्ष संरचनाओं में समूहीकृत किया जा सकता है, जो नियंत्रण प्रवाह#लूप्स और [[रिकर्सन (कंप्यूटर विज्ञान)]] जैसी विशेष प्रोग्रामिंग संरचनाओं के लिए उपयुक्त है।
*मेमोरी पूल को पदानुक्रमित ट्री संरचनाओं में समूहीकृत किया जा सकता है, जो नियंत्रण प्रवाह लूप्स और [[रिकर्सन (कंप्यूटर विज्ञान)|रिकर्सन]] जैसी विशेष प्रोग्रामिंग संरचनाओं के लिए उपयुक्त होता है।
*निश्चित आकार के ब्लॉक मेमोरी पूल को आवंटित ब्लॉक के आकार जैसी विशेषताओं का वर्णन करते हुए, प्रत्येक आवंटन के लिए आवंटन मेटाडेटा संग्रहीत करने की आवश्यकता नहीं होती है। विशेष रूप से छोटे आवंटन के लिए, यह पर्याप्त स्थान बचत प्रदान करता है।
*निश्चित आकृति के ब्लॉक मेमोरी पूल को एलोटेड ब्लॉक के आकृति जैसी विशेषताओं का वर्णन करते हुए, प्रत्येक एलोकेशन के लिए एलोकेशन मेटाडेटा संग्रहीत करने की आवश्यकता नहीं होती है। विशेष रूप से छोटे एलोकेशन के लिए, यह पर्याप्त स्थान बचत प्रदान करता है।
*आउट ऑफ मेमोरी त्रुटियों से बचने के लिए वास्तविक समय प्रणालियों पर नियतात्मक व्यवहार की अनुमति देता है।
*आउट ऑफ मेमोरी त्रुटियों से बचने के लिए वास्तविक समय प्रणालियों पर नियतात्मक व्यवहार की अनुमति देता है।
कमियां
हानियाँ
*मेमोरी पूल को उस एप्लिकेशन के लिए ट्यून करने की आवश्यकता हो सकती है जो उन्हें तैनात करता है।
*मेमोरी पूल को उस एप्लिकेशन के लिए ट्यून करने की आवश्यकता हो सकती है जो उन्हें स्थापित करता है।


==यह भी देखें==
==यह भी देखें==
* नि:शुल्क सूची
* नि:शुल्क सूची
* [[ऑब्जेक्ट पूल]]
* [[ऑब्जेक्ट पूल]]
* [[स्लैब आवंटन]]
* [[स्लैब आवंटन|स्लैब एलोकेशन]]  


==बाहरी संबंध==
==बाहरी संबंध==
Line 37: Line 34:




{{DEFAULTSORT:Memory Pool}}[[Category: स्मृति प्रबंधन]]
{{DEFAULTSORT:Memory Pool}}
 
 


[[Category: Machine Translated Page]]
[[Category:Created On 11/07/2023|Memory Pool]]
[[Category:Created On 11/07/2023]]
[[Category:Lua-based templates|Memory Pool]]
[[Category:Machine Translated Page|Memory Pool]]
[[Category:Pages with script errors|Memory Pool]]
[[Category:Templates Vigyan Ready|Memory Pool]]
[[Category:Templates that add a tracking category|Memory Pool]]
[[Category:Templates that generate short descriptions|Memory Pool]]
[[Category:Templates using TemplateData|Memory Pool]]
[[Category:स्मृति प्रबंधन|Memory Pool]]

Latest revision as of 15:26, 31 July 2023

मेमोरी पूल, जिसे निश्चित आकृति के ब्लॉक एलोकेशन भी कहा जाता है, मेमोरी प्रबंधन के लिए पूल का उपयोग होता है जो डायनमिक मेमोरी एलोकेशन की अनुमति देता है। गतिशील मेमोरी एलोकेशन मॉलोक और सी++ के नवीन जैसी तकनीकों के उपयोग से प्राप्त किया जा सकता है और किया भी गया है; यघपि स्थापित और विश्वसनीय कार्यान्वयन, ये परिवर्तनीय ब्लॉक आकृतियों के कारण विखंडन से घीरे होते हैं, प्रदर्शन के कारण इन्हें रियल टाइम सिस्टम में उपयोग करने की अनुशंसा नहीं की जाती है। अधिक कुशल समाधान समान आकृति वाले विभिन्न मेमोरी ब्लॉकों को पूर्व-एलोकेशन करना होता है जिन्हें मेमोरी पूल कहा जाता है। एप्लिकेशन रन टाइम (प्रोग्राम जीवनचक्र चरण) पर हैंडल द्वारा प्रदर्शित किये गए ब्लॉकों को आवंटित, अभिगम और मुक्त कर सकता है।

कई रियल-टाइम ऑपरेटिंग सिस्टम मेमोरी पूल का उपयोग करते हैं, जैसे विनिमय प्रसंस्करण सुविधा

कुछ प्रणालियाँ, जैसे वेब सर्वर एनजीआईएनएक्स, चर-आकृति एलोकेशन के समूह को संदर्भित करने के लिए मेमोरी पूल शब्द का उपयोग करती हैं, जिन्हें पश्चात् में एक ही बार में हटाया जा सकता है। इसे एक क्षेत्र के नाम से भी जाना जाता है; क्षेत्र-आधारित मेमोरी प्रबंधन देखें।

सरल मेमोरी पूल कार्यान्वयन

साधारण मेमोरी पूल मॉड्यूल, उदाहरण के लिए, मॉड्यूल को स्थापित करने वाले एप्लिकेशन के लिए अनुकूलित ब्लॉक आकृति के साथ कंपाइल समय पर तीन पूल निर्धारित कर सकता है। एप्लिकेशन निम्नलिखित इंटरफ़ेस के माध्यम से मेमोरी एलोकेशन, अभिग्म और मुक्त कर सकता है:

  • पूल से मेमोरी एलोकेशन करें। फ़ंक्शन उस पूल का निर्धारण करेगा जहां आवश्यक ब्लॉक उपयुक्त स्थित होता है। यदि उस पूल के सभी ब्लॉक पहले से ही आरक्षित होते हैं, तो फ़ंक्शन अगले बड़े पूल में से को अन्वेषण का प्रयास करता है। एलोटेड मेमोरी ब्लॉक को हैंडल के साथ प्रदर्शित किया जाता है।
  • आवंटित मेमोरी तक अभिग्म सूचक प्राप्त करें।
  • पूर्व में एलोटेड मेमोरी ब्लॉक को मुक्त करें।
  • उदाहरण के लिए हैंडल को के साथ कार्यान्वित किया जा सकता है। मॉड्यूल हैंडल को पूल क्रम-सूची, मेमोरी ब्लॉक क्रम-सूची और संस्करण में विभाजित करके आंतरिक रूप से व्याख्या कर सकता है। पूल और मेमोरी ब्लॉक क्रम-सूची हैंडल के साथ संबंधित ब्लॉक तक शीघ्रता से अभिग्म की अनुमति देता है, जबकि संस्करण, जो प्रत्येक नए एलोकेशन पर बढ़ाया जाता है, उन हैंडल का पता लगाने की अनुमति देता है जिनका मेमोरी ब्लॉक पहले ही मुक्त हो चुकी होती है (बहुत लंबे समय तक रखे गए हैंडल के कारण)।

मेमोरी पूल विरुद्ध मॉलोक

लाभ

  • मेमोरी पूल निरंतर निष्पादन समय के साथ मेमोरी एलोकेशन की अनुमति देता है। यदि प्रत्येक वस्तु के लिए मेमोरी आवंटित करने के लिए मॉलोक का उपयोग किया जाता है, तो पूल में हजारों वस्तुओं के लिए मेमोरी रिलीज़ मात्र एक संचाल होता है, नाकि एक- एक करके होता है।
  • मेमोरी पूल को पदानुक्रमित ट्री संरचनाओं में समूहीकृत किया जा सकता है, जो नियंत्रण प्रवाह लूप्स और रिकर्सन जैसी विशेष प्रोग्रामिंग संरचनाओं के लिए उपयुक्त होता है।
  • निश्चित आकृति के ब्लॉक मेमोरी पूल को एलोटेड ब्लॉक के आकृति जैसी विशेषताओं का वर्णन करते हुए, प्रत्येक एलोकेशन के लिए एलोकेशन मेटाडेटा संग्रहीत करने की आवश्यकता नहीं होती है। विशेष रूप से छोटे एलोकेशन के लिए, यह पर्याप्त स्थान बचत प्रदान करता है।
  • आउट ऑफ मेमोरी त्रुटियों से बचने के लिए वास्तविक समय प्रणालियों पर नियतात्मक व्यवहार की अनुमति देता है।

हानियाँ

  • मेमोरी पूल को उस एप्लिकेशन के लिए ट्यून करने की आवश्यकता हो सकती है जो उन्हें स्थापित करता है।

यह भी देखें

बाहरी संबंध