स्मृति चिन्ह पैटर्न: Difference between revisions
No edit summary |
No edit summary |
||
(5 intermediate revisions by 4 users not shown) | |||
Line 1: | Line 1: | ||
{{Short description|Software design pattern}} | {{Short description|Software design pattern}} | ||
स्मृति चिन्ह पैटर्न एक सॉफ्टवेयर डिजाइन पैटर्न है जो किसी ऑब्जेक्ट की व्यक्तिगत आंतरिक स्थिति को उजागर करता है। इसका उपयोग कैसे किया जा सकता है इसका | स्मृति चिन्ह पैटर्न एक सॉफ्टवेयर डिजाइन पैटर्न है जो किसी ऑब्जेक्ट की व्यक्तिगत आंतरिक स्थिति को उजागर करता है। इसका उपयोग कैसे किया जा सकता है इसका उदाहरण किसी ऑब्जेक्ट को उसकी पूर्व स्थिति में पुनर्स्थापित करना है(रोलबैक के माध्यम से पूर्ववत करें), दूसरा संस्करण है, दूसरा कस्टम क्रमांकन है। | ||
स्मृति चिन्ह पैटर्न को तीन ऑब्जेक्ट के साथ लागू किया गया है: ''प्रवर्तक'', एक ''कार्यवाहक'' और एक ''स्मृति चिन्ह''। प्रवर्तक कुछ ऐसे ऑब्जेक्ट है जिसकी आंतरिक स्थिति होती है। कार्यवाहक प्रवर्तक के लिए कुछ करने जा रहा है, परन्तु | स्मृति चिन्ह पैटर्न को तीन ऑब्जेक्ट के साथ लागू किया गया है: ''प्रवर्तक'', एक ''कार्यवाहक'' और एक ''स्मृति चिन्ह''। प्रवर्तक कुछ ऐसे ऑब्जेक्ट है जिसकी आंतरिक स्थिति होती है। कार्यवाहक प्रवर्तक के लिए कुछ करने जा रहा है, परन्तु परिवर्तन को पूर्ववत करने में सक्षम होना चाहता है। कार्यवाहक पूर्व प्रवर्तक से स्मृति चिन्ह ऑब्जेक्ट माँगता है। फिर यह जो भी संचालन(या संचालन का क्रम) करता है वह करता है। संचालन से पूर्व स्थिति में वापस आने के लिए, यह स्मृति चिन्ह ऑब्जेक्ट को प्रवर्तक को लौटाता है। स्मृति चिन्ह अपने आप में एक अपारदर्शी ऑब्जेक्ट है(जिसे कार्यवाहक बदल नहीं सकता है या नहीं बदलना चाहिए)। इस पैटर्न का उपयोग करते समय, ध्यान रखा जाना चाहिए कि प्रवर्तक अन्य ऑब्जेक्ट या संसाधनों को बदल सकता है - स्मृति चिन्ह पैटर्न एक ही ऑब्जेक्ट पर संचालित होता है। | ||
स्मृति चिन्ह पैटर्न के उत्कृष्ट उदाहरणों में एक छद्म यादृच्छिक संख्या | स्मृति चिन्ह पैटर्न के उत्कृष्ट उदाहरणों में एक छद्म यादृच्छिक संख्या उत्पादक सम्मिलित है(पीआरएनजी का प्रत्येक उपभोक्ता कार्यवाहक के रूप में कार्य करता है जो एक ही बीज(स्मृति चिन्ह) के साथ पीआरएनजी(प्रवर्तक) को छद्म यादृच्छिक संख्याओं के समान अनुक्रम का उत्पादन करने के लिए प्रारंभ कर सकता है) और स्थिति एक परिमित स्थिति मशीन में। | ||
== | == अवलोकन == | ||
स्मृति चिन्ह डिज़ाइन पैटर्न उन तेईस प्रसिद्ध डिज़ाइन पैटर्न में से एक है जो यह वर्णन करता है कि | स्मृति चिन्ह डिज़ाइन पैटर्न उन तेईस प्रसिद्ध डिज़ाइन पैटर्न में से एक है जो यह वर्णन करता है कि नम्य और पुन: प्रयोज्य ऑब्जेक्ट-ओरिएंटेड सॉफ़्टवेयर को डिज़ाइन करने के लिए आवर्ती डिज़ाइन समस्याओं को कैसे हल किया जाए, अर्थात ऐसी ऑब्जेक्ट जिन्हें लागू करना, बदलना, परीक्षण करना और पुन: उपयोग करना सरल है। स्मृति चिन्ह पैटर्न को प्रारंभिक एचपी उत्पादों के लिए नूह थॉम्पसन, डेविड एस्पिरिटु और डॉ. ड्रू क्लिंकेनबर्ड द्वारा बनाया गया था। | ||
=== स्मृति चिन्ह डिज़ाइन पैटर्न किन समस्याओं को हल कर सकता है? === | === स्मृति चिन्ह डिज़ाइन पैटर्न किन समस्याओं को हल कर सकता है? === | ||
* किसी ऑब्जेक्ट की आंतरिक स्थिति को | * किसी ऑब्जेक्ट की आंतरिक स्थिति को बाह्य रूप से सुरक्षित किया जाना चाहिए ताकि ऑब्जेक्ट को बाद में इस स्थिति में पुनःस्थापित किया जा सके। | ||
* ऑब्जेक्ट के | * ऑब्जेक्ट के संपुटीकरण का उल्लंघन नहीं किया जाना चाहिए। | ||
समस्या यह है कि | समस्या यह है कि ठीक रूप से डिज़ाइन की गई ऑब्जेक्ट को संपुट किया जाता है ताकि उसका प्रतिनिधित्व(डेटा संरचना) ऑब्जेक्ट के अंदर छिपा हुआ है और ऑब्जेक्ट के बाहर से एक्सेस नहीं किया जा सकता है। | ||
ऑब्जेक्ट के अंदर छिपा हुआ है और ऑब्जेक्ट के बाहर से एक्सेस नहीं किया जा सकता है। | |||
=== स्मृति चिन्ह डिज़ाइन पैटर्न किस समाधान का वर्णन करता है? === | === स्मृति चिन्ह डिज़ाइन पैटर्न किस समाधान का वर्णन करता है? === | ||
किसी ऑब्जेक्ट (प्रवर्तक) को स्वयं के लिए उत्तरदायी बनाएं | किसी ऑब्जेक्ट(प्रवर्तक) को स्वयं के लिए उत्तरदायी बनाएं | ||
* अपनी आंतरिक स्थिति को एक (स्मृति चिन्ह) ऑब्जेक्ट में | * अपनी आंतरिक स्थिति को एक(स्मृति चिन्ह) ऑब्जेक्ट में रक्षित करना और | ||
* एक (स्मृति चिन्ह) ऑब्जेक्ट से पूर्व | * एक(स्मृति चिन्ह) ऑब्जेक्ट से पूर्व स्थिति में पुनर्स्थापित करना। | ||
स्मृति चिन्ह बनाने वाले को ही इसे एक्सेस करने की अनुमति है। | स्मृति चिन्ह बनाने वाले को ही इसे एक्सेस करने की अनुमति है। | ||
ग्राहक(कार्यवाहक) प्रवर्तक से एक स्मृति चिन्ह का अनुरोध कर सकता है(प्रवर्तक की आंतरिक स्थिति को रक्षित करने के लिए) और एक स्मृति चिन्ह को प्रवर्तक को वापस भेज सकता है(पूर्व स्थिति को पुनर्स्थापित करने के लिए)। | |||
यह एक प्रवर्तक की आंतरिक स्थिति को उसके | यह एक प्रवर्तक की आंतरिक स्थिति को उसके संपुटीकरण का उल्लंघन किए बिना रक्षित करने और पुनर्स्थापित करने में सक्षम बनाता है। | ||
नीचे यूएमएल | नीचे यूएमएल वर्ग और अनुक्रम आरेख भी देखें। | ||
== संरचना == | == संरचना == | ||
=== यूएमएल वर्ग और अनुक्रम आरेख === | === यूएमएल वर्ग और अनुक्रम आरेख === | ||
[[File:w3sDesign Memento Design Pattern UML.jpg|frame|none|स्मृति चिन्ह डिजाइन पैटर्न के लिए एक | [[File:w3sDesign Memento Design Pattern UML.jpg|frame|none|स्मृति चिन्ह डिजाइन पैटर्न के लिए एक प्रतिरूप यूएमएल वर्ग और अनुक्रम आरेख। <ref>{{cite web|title=मेमेंटो डिजाइन पैटर्न - संरचना और सहयोग|url=http://w3sdesign.com/?gr=b06&ugr=struct|website=w3sDesign.com|access-date=2017-08-12}}</ref>]]उपरोक्त यूएमएल वर्ग आरेख में, <code>Caretaker</code> वर्ग रक्षण(<code>createMemento()</code>) पुनर्स्थापित करना(<code>restore(memento)</code>) प्रवर्तक की आंतरिक स्थिति के लिए <code>Originator</code> वर्ग को संदर्भित करता है।<br> <code>Originator</code> वर्ग लागू करता है<br>(1) <code>createMemento()</code> एक <code>Memento</code> ऑब्जेक्ट बनाकर और वापस करके जो प्रवर्तक की वर्तमान आंतरिक स्थिति को संग्रहीत करती है और<br>(2) <code>restore(memento)</code> <code>Memento</code> ऑब्जेक्ट में पारित से स्थिति को पुनर्स्थापित करके।<br> | ||
<br> <code>Originator</code | |||
<br> | |||
(1) <code>createMemento()</code> | |||
और | |||
<br> | |||
(2) <code>restore(memento)</code> | |||
<br> | |||
[[एकीकृत मॉडलिंग भाषा]] अनुक्रम आरेख | [[एकीकृत मॉडलिंग भाषा]] अनुक्रम आरेख क्रम परस्पर क्रिया दिखाता है:<br>(1) प्रवर्तक की आंतरिक स्थिति को सहेजना: <code>Caretaker</code> ऑब्जेक्ट <code>Originator</code> ऑब्जेक्ट पर <code>createMemento()</code> कॉल करता है, जो एक <code>Memento</code> ऑब्जेक्ट बनाता है, इसकी वर्तमान आंतरिक स्थिति(<code>setState()</code>) को रक्षित करता है, और <code>Memento</code> को <code>Caretaker</code> पर लौटाता है। <br>(2) प्रवर्तक की आंतरिक स्थिति को पुनर्स्थापित करना: <code>Caretaker</code> <code>Originator</code> ऑब्जेक्ट पर <code>restore(memento)</code> को कॉल करता है और उस <code>Memento</code> ऑब्जेक्ट को निर्दिष्ट करता है जो उस स्थिति को संग्रहीत करता है जिसे पुनर्स्थापित किया जाना चाहिए। <code>Originator</code> को अपनी स्थिति स्थापित करने के लिए <code>Memento</code> से स्थिति(<code>getState()</code>)स्थिति प्राप्त होती है। | ||
<br> | |||
(1) प्रवर्तक की आंतरिक स्थिति को सहेजना: <code>Caretaker</code | |||
जो एक | |||
इसकी वर्तमान आंतरिक स्थिति (<code>setState()</code>), और | |||
<br> | |||
(2) प्रवर्तक की आंतरिक स्थिति को | |||
== जावा उदाहरण == | == जावा उदाहरण == | ||
{{wikibooks|Computer Science Design Patterns|Memento|Memento implementations in various languages}} | {{wikibooks|Computer Science Design Patterns|Memento|Memento implementations in various languages}} | ||
Line 115: | Line 96: | ||
</syntaxhighlight> | </syntaxhighlight> | ||
आउटपुट है: | आउटपुट है: | ||
Originator: Setting state to State1 | |||
Originator: Setting state to State2 | |||
Originator: Saving to Memento. | |||
Originator: Setting state to State3 | |||
Originator: Saving to Memento. | |||
Originator: Setting state to State4 | |||
यह उदाहरण स्थिति के रूप में | Originator: State after restoring from Memento: State3 | ||
लगभग | यह उदाहरण स्थिति के रूप में स्ट्रिंग का उपयोग करता है, जो जावा में एक अपरिवर्तनीय ऑब्जेक्ट है। वास्तविक जीवन के परिदृश्य में स्थिति लगभग सदैव एक परिवर्तनशील ऑब्जेक्ट होगा, जिस स्थिति में स्थिति की एक प्रति बनाई जानी चाहिए। | ||
यह कहा जाना चाहिए कि दिखाए गए कार्यान्वयन में एक | यह कहा जाना चाहिए कि दिखाए गए कार्यान्वयन में एक कमी है: यह एक आंतरिक वर्ग की घोषणा करता है। यह ठीक होगा यदि यह स्मृति चिन्ह कार्यनीति एक से अधिक प्रवर्तकों पर लागू हो। | ||
स्मृति चिन्ह प्राप्त करने के मुख्य रूप से तीन अन्य | स्मृति चिन्ह प्राप्त करने के मुख्य रूप से तीन अन्य विधियां हैं: | ||
# क्रमांकन। | # क्रमांकन। | ||
# एक ही पैकेज में घोषित वर्ग। | # एक ही पैकेज में घोषित वर्ग। | ||
# ऑब्जेक्ट को एक प्रॉक्सी के माध्यम से भी एक्सेस किया जा सकता है, जो ऑब्जेक्ट पर किसी भी | # ऑब्जेक्ट को एक प्रॉक्सी के माध्यम से भी एक्सेस किया जा सकता है, जो ऑब्जेक्ट पर किसी भी रक्षित/पुनर्स्थापित संचालन को प्राप्त कर सकता है। | ||
== सी # उदाहरण == | == सी # उदाहरण == | ||
स्मृति चिन्ह पैटर्न किसी व्यक्ति को | स्मृति चिन्ह पैटर्न किसी व्यक्ति को संपुटीकरण का उल्लंघन किए बिना किसी ऑब्जेक्ट की आंतरिक स्थिति को अधिकृत करने की अनुमति देता है जैसे कि बाद में यदि आवश्यक हो तो परिवर्तनों को पूर्ववत/वापस कर सकता है। यहाँ कोई देख सकता है कि स्मृति चिन्ह ऑब्जेक्ट वस्तुत: ऑब्जेक्ट में किए गए परिवर्तनों को वापस लाने के लिए उपयोग की जाती है। | ||
<syntaxhighlight lang="csharp"> | <syntaxhighlight lang="csharp"> | ||
class Memento | class Memento | ||
Line 312: | Line 293: | ||
== | ==बाह्य संबंध== | ||
*Description of Memento Pattern in Ada | *Description of Memento Pattern in Ada | ||
* Memento UML Class Diagram with C# and .NET code samples | * Memento UML Class Diagram with C# and .NET code samples | ||
Line 318: | Line 299: | ||
* Memento Design Pattern using Java | * Memento Design Pattern using Java | ||
[[Category:Collapse templates]] | |||
[[Category: | |||
[[Category:Created On 02/03/2023]] | [[Category:Created On 02/03/2023]] | ||
[[Category:Lua-based templates]] | |||
[[Category:Machine Translated Page]] | |||
[[Category:Navigational boxes| ]] | |||
[[Category:Navigational boxes without horizontal lists]] | |||
[[Category:Pages with script errors]] | |||
[[Category:Short description with empty Wikidata description]] | |||
[[Category:Sidebars with styles needing conversion]] | |||
[[Category:Template documentation pages|Documentation/doc]] | |||
[[Category:Templates Vigyan Ready]] | |||
[[Category:Templates that add a tracking category]] | |||
[[Category:Templates that generate short descriptions]] | |||
[[Category:Templates using TemplateData]] |
Latest revision as of 10:07, 15 March 2023
स्मृति चिन्ह पैटर्न एक सॉफ्टवेयर डिजाइन पैटर्न है जो किसी ऑब्जेक्ट की व्यक्तिगत आंतरिक स्थिति को उजागर करता है। इसका उपयोग कैसे किया जा सकता है इसका उदाहरण किसी ऑब्जेक्ट को उसकी पूर्व स्थिति में पुनर्स्थापित करना है(रोलबैक के माध्यम से पूर्ववत करें), दूसरा संस्करण है, दूसरा कस्टम क्रमांकन है।
स्मृति चिन्ह पैटर्न को तीन ऑब्जेक्ट के साथ लागू किया गया है: प्रवर्तक, एक कार्यवाहक और एक स्मृति चिन्ह। प्रवर्तक कुछ ऐसे ऑब्जेक्ट है जिसकी आंतरिक स्थिति होती है। कार्यवाहक प्रवर्तक के लिए कुछ करने जा रहा है, परन्तु परिवर्तन को पूर्ववत करने में सक्षम होना चाहता है। कार्यवाहक पूर्व प्रवर्तक से स्मृति चिन्ह ऑब्जेक्ट माँगता है। फिर यह जो भी संचालन(या संचालन का क्रम) करता है वह करता है। संचालन से पूर्व स्थिति में वापस आने के लिए, यह स्मृति चिन्ह ऑब्जेक्ट को प्रवर्तक को लौटाता है। स्मृति चिन्ह अपने आप में एक अपारदर्शी ऑब्जेक्ट है(जिसे कार्यवाहक बदल नहीं सकता है या नहीं बदलना चाहिए)। इस पैटर्न का उपयोग करते समय, ध्यान रखा जाना चाहिए कि प्रवर्तक अन्य ऑब्जेक्ट या संसाधनों को बदल सकता है - स्मृति चिन्ह पैटर्न एक ही ऑब्जेक्ट पर संचालित होता है।
स्मृति चिन्ह पैटर्न के उत्कृष्ट उदाहरणों में एक छद्म यादृच्छिक संख्या उत्पादक सम्मिलित है(पीआरएनजी का प्रत्येक उपभोक्ता कार्यवाहक के रूप में कार्य करता है जो एक ही बीज(स्मृति चिन्ह) के साथ पीआरएनजी(प्रवर्तक) को छद्म यादृच्छिक संख्याओं के समान अनुक्रम का उत्पादन करने के लिए प्रारंभ कर सकता है) और स्थिति एक परिमित स्थिति मशीन में।
अवलोकन
स्मृति चिन्ह डिज़ाइन पैटर्न उन तेईस प्रसिद्ध डिज़ाइन पैटर्न में से एक है जो यह वर्णन करता है कि नम्य और पुन: प्रयोज्य ऑब्जेक्ट-ओरिएंटेड सॉफ़्टवेयर को डिज़ाइन करने के लिए आवर्ती डिज़ाइन समस्याओं को कैसे हल किया जाए, अर्थात ऐसी ऑब्जेक्ट जिन्हें लागू करना, बदलना, परीक्षण करना और पुन: उपयोग करना सरल है। स्मृति चिन्ह पैटर्न को प्रारंभिक एचपी उत्पादों के लिए नूह थॉम्पसन, डेविड एस्पिरिटु और डॉ. ड्रू क्लिंकेनबर्ड द्वारा बनाया गया था।
स्मृति चिन्ह डिज़ाइन पैटर्न किन समस्याओं को हल कर सकता है?
- किसी ऑब्जेक्ट की आंतरिक स्थिति को बाह्य रूप से सुरक्षित किया जाना चाहिए ताकि ऑब्जेक्ट को बाद में इस स्थिति में पुनःस्थापित किया जा सके।
- ऑब्जेक्ट के संपुटीकरण का उल्लंघन नहीं किया जाना चाहिए।
समस्या यह है कि ठीक रूप से डिज़ाइन की गई ऑब्जेक्ट को संपुट किया जाता है ताकि उसका प्रतिनिधित्व(डेटा संरचना) ऑब्जेक्ट के अंदर छिपा हुआ है और ऑब्जेक्ट के बाहर से एक्सेस नहीं किया जा सकता है।
स्मृति चिन्ह डिज़ाइन पैटर्न किस समाधान का वर्णन करता है?
किसी ऑब्जेक्ट(प्रवर्तक) को स्वयं के लिए उत्तरदायी बनाएं
- अपनी आंतरिक स्थिति को एक(स्मृति चिन्ह) ऑब्जेक्ट में रक्षित करना और
- एक(स्मृति चिन्ह) ऑब्जेक्ट से पूर्व स्थिति में पुनर्स्थापित करना।
स्मृति चिन्ह बनाने वाले को ही इसे एक्सेस करने की अनुमति है।
ग्राहक(कार्यवाहक) प्रवर्तक से एक स्मृति चिन्ह का अनुरोध कर सकता है(प्रवर्तक की आंतरिक स्थिति को रक्षित करने के लिए) और एक स्मृति चिन्ह को प्रवर्तक को वापस भेज सकता है(पूर्व स्थिति को पुनर्स्थापित करने के लिए)।
यह एक प्रवर्तक की आंतरिक स्थिति को उसके संपुटीकरण का उल्लंघन किए बिना रक्षित करने और पुनर्स्थापित करने में सक्षम बनाता है।
नीचे यूएमएल वर्ग और अनुक्रम आरेख भी देखें।
संरचना
यूएमएल वर्ग और अनुक्रम आरेख
उपरोक्त यूएमएल वर्ग आरेख में, Caretaker
वर्ग रक्षण(createMemento()
) पुनर्स्थापित करना(restore(memento)
) प्रवर्तक की आंतरिक स्थिति के लिए Originator
वर्ग को संदर्भित करता है।
Originator
वर्ग लागू करता है
(1) createMemento()
एक Memento
ऑब्जेक्ट बनाकर और वापस करके जो प्रवर्तक की वर्तमान आंतरिक स्थिति को संग्रहीत करती है और
(2) restore(memento)
Memento
ऑब्जेक्ट में पारित से स्थिति को पुनर्स्थापित करके।
एकीकृत मॉडलिंग भाषा अनुक्रम आरेख क्रम परस्पर क्रिया दिखाता है:
(1) प्रवर्तक की आंतरिक स्थिति को सहेजना: Caretaker
ऑब्जेक्ट Originator
ऑब्जेक्ट पर createMemento()
कॉल करता है, जो एक Memento
ऑब्जेक्ट बनाता है, इसकी वर्तमान आंतरिक स्थिति(setState()
) को रक्षित करता है, और Memento
को Caretaker
पर लौटाता है।
(2) प्रवर्तक की आंतरिक स्थिति को पुनर्स्थापित करना: Caretaker
Originator
ऑब्जेक्ट पर restore(memento)
को कॉल करता है और उस Memento
ऑब्जेक्ट को निर्दिष्ट करता है जो उस स्थिति को संग्रहीत करता है जिसे पुनर्स्थापित किया जाना चाहिए। Originator
को अपनी स्थिति स्थापित करने के लिए Memento
से स्थिति(getState()
)स्थिति प्राप्त होती है।
जावा उदाहरण
निम्नलिखित जावा प्रोग्राम स्मृति चिन्ह पैटर्न के पूर्ववत उपयोग को दिखाता है।
import java.util.List;
import java.util.ArrayList;
class Originator {
private String state;
// The class could also contain additional data that is not part of the
// state saved in the memento..
public void set(String state) {
this.state = state;
System.out.println("Originator: Setting state to " + state);
}
public Memento saveToMemento() {
System.out.println("Originator: Saving to Memento.");
return new Memento(this.state);
}
public void restoreFromMemento(Memento memento) {
this.state = memento.getSavedState();
System.out.println("Originator: State after restoring from Memento: " + state);
}
public static class Memento {
private final String state;
public Memento(String stateToSave) {
state = stateToSave;
}
// accessible by outer class only
private String getSavedState() {
return state;
}
}
}
class Caretaker {
public static void main(String[] args) {
List<Originator.Memento> savedStates = new ArrayList<Originator.Memento>();
Originator originator = new Originator();
originator.set("State1");
originator.set("State2");
savedStates.add(originator.saveToMemento());
originator.set("State3");
// We can request multiple mementos, and choose which one to roll back to.
savedStates.add(originator.saveToMemento());
originator.set("State4");
originator.restoreFromMemento(savedStates.get(1));
}
}
आउटपुट है:
Originator: Setting state to State1 Originator: Setting state to State2
Originator: Saving to Memento.
Originator: Setting state to State3 Originator: Saving to Memento.
Originator: Setting state to State4 Originator: State after restoring from Memento: State3
यह उदाहरण स्थिति के रूप में स्ट्रिंग का उपयोग करता है, जो जावा में एक अपरिवर्तनीय ऑब्जेक्ट है। वास्तविक जीवन के परिदृश्य में स्थिति लगभग सदैव एक परिवर्तनशील ऑब्जेक्ट होगा, जिस स्थिति में स्थिति की एक प्रति बनाई जानी चाहिए।
यह कहा जाना चाहिए कि दिखाए गए कार्यान्वयन में एक कमी है: यह एक आंतरिक वर्ग की घोषणा करता है। यह ठीक होगा यदि यह स्मृति चिन्ह कार्यनीति एक से अधिक प्रवर्तकों पर लागू हो।
स्मृति चिन्ह प्राप्त करने के मुख्य रूप से तीन अन्य विधियां हैं:
- क्रमांकन।
- एक ही पैकेज में घोषित वर्ग।
- ऑब्जेक्ट को एक प्रॉक्सी के माध्यम से भी एक्सेस किया जा सकता है, जो ऑब्जेक्ट पर किसी भी रक्षित/पुनर्स्थापित संचालन को प्राप्त कर सकता है।
सी # उदाहरण
स्मृति चिन्ह पैटर्न किसी व्यक्ति को संपुटीकरण का उल्लंघन किए बिना किसी ऑब्जेक्ट की आंतरिक स्थिति को अधिकृत करने की अनुमति देता है जैसे कि बाद में यदि आवश्यक हो तो परिवर्तनों को पूर्ववत/वापस कर सकता है। यहाँ कोई देख सकता है कि स्मृति चिन्ह ऑब्जेक्ट वस्तुत: ऑब्जेक्ट में किए गए परिवर्तनों को वापस लाने के लिए उपयोग की जाती है।
class Memento
{
private readonly string savedState;
private Memento(string stateToSave)
{
savedState = stateToSave;
}
public class Originator
{
private string state;
// The class could also contain additional data that is not part of the
// state saved in the memento.
public void Set(string state)
{
Console.WriteLine("Originator: Setting state to " + state);
this.state = state;
}
public Memento SaveToMemento()
{
Console.WriteLine("Originator: Saving to Memento.");
return new Memento(state);
}
public void RestoreFromMemento(Memento memento)
{
state = memento.savedState;
Console.WriteLine("Originator: State after restoring from Memento: " + state);
}
}
}
class Caretaker
{
static void Main(string[] args)
{
var savedStates = new List<Memento>();
var originator = new Memento.Originator();
originator.Set("State1");
originator.Set("State2");
savedStates.Add(originator.SaveToMemento());
originator.Set("State3");
// We can request multiple mementos, and choose which one to roll back to.
savedStates.Add(originator.SaveToMemento());
originator.Set("State4");
originator.RestoreFromMemento(savedStates[1]);
}
}
पायथन उदाहरण
"""
Memento pattern example.
"""
class Memento:
def __init__(self, state) -> None:
self._state = state
def get_saved_state(self):
return self._state
class Originator:
_state = ""
def set(self, state) -> None:
print("Originator: Setting state to", state)
self._state = state
def save_to_memento(self) -> Memento:
print("Originator: Saving to Memento.")
return Memento(self._state)
def restore_from_memento(self, memento) -> None:
self._state = memento.get_saved_state()
print("Originator: State after restoring from Memento:", self._state)
saved_states = []
originator = Originator()
originator.set("State1")
originator.set("State2")
saved_states.append(originator.save_to_memento())
originator.set("State3")
saved_states.append(originator.save_to_memento())
originator.set("State4")
originator.restore_from_memento(saved_states[1])
जावास्क्रिप्ट उदाहरण
// The Memento pattern is used to save and restore the state of an object.
// A memento is a snapshot of an object's state.
var Memento = {// Namespace: Memento
savedState : null, // The saved state of the object.
save : function(state) { // Save the state of an object.
this.savedState = state;
},
restore : function() { // Restore the state of an object.
return this.savedState;
}
};
// The Originator is the object that creates the memento.
// defines a method for saving the state inside a memento.
var Originator = {// Namespace: Originator
state : null, // The state to be stored
// Creates a new originator with an initial state of null
createMemento : function() {
return {
state : this.state // The state is copied to the memento.
};
},
setMemento : function(memento) { // Sets the state of the originator from a memento
this.state = memento.state;
}
};
// The Caretaker stores mementos of the objects and
// provides operations to retrieve them.
var Caretaker = {// Namespace: Caretaker
mementos : [], // The mementos of the objects.
addMemento : function(memento) { // Add a memento to the collection.
this.mementos.push(memento);
},
getMemento : function(index) { // Get a memento from the collection.
return this.mementos[index];
}
};
var action_step = "Foo"; // The action to be executed/the object state to be stored.
var action_step_2 = "Bar"; // The action to be executed/the object state to be stored.
// set the initial state
Originator.state = action_step;
Caretaker.addMemento(Originator.createMemento());// save the state to the history
console.log("Initial State: " + Originator.state); // Foo
// change the state
Originator.state = action_step_2;
Caretaker.addMemento(Originator.createMemento()); // save the state to the history
console.log("State After Change: " + Originator.state); // Bar
// restore the first state - undo
Originator.setMemento(Caretaker.getMemento(0));
console.log("State After Undo: " + Originator.state); // Foo
// restore the second state - redo
Originator.setMemento(Caretaker.getMemento(1));
console.log("State After Redo: " + Originator.state); // Bar
संदर्भ
- ↑ "मेमेंटो डिजाइन पैटर्न - संरचना और सहयोग". w3sDesign.com. Retrieved 2017-08-12.
बाह्य संबंध
- Description of Memento Pattern in Ada
- Memento UML Class Diagram with C# and .NET code samples
- SourceMaking Tutorial
- Memento Design Pattern using Java