इटरेटर पैटर्न: Difference between revisions
(Created page with "ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग में, इटरेटर पैटर्न एक डिज़ाइन...") |
No edit summary |
||
Line 1: | Line 1: | ||
[[ ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग ]] में, [[इटरेटर]] पैटर्न | [[ ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग |ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग]] में, '''[[इटरेटर]] पैटर्न''' डिज़ाइन पैटर्न (कंप्यूटर साइंस) है जिसमें इटरेटर का उपयोग संग्रह (अमूर्त डेटा प्रकार) को पार करने और कंटेनर के तत्वों तक पहुंचने के लिए किया जाता है। पुनरावर्तक पैटर्न कंटेनरों से एल्गोरिदम को अलग करता है; कुछ मामलों में, एल्गोरिदम आवश्यक रूप से कंटेनर-विशिष्ट होते हैं और इस प्रकार उन्हें अलग नहीं किया जा सकता है। | ||
उदाहरण के लिए, काल्पनिक [[ कलन विधि ]] ''SearchForElement'' को कंटेनर-विशिष्ट एल्गोरिथम के रूप में लागू करने के बजाय आमतौर पर | उदाहरण के लिए, काल्पनिक [[ कलन विधि ]] ''SearchForElement'' को कंटेनर-विशिष्ट एल्गोरिथम के रूप में लागू करने के बजाय आमतौर पर निर्दिष्ट प्रकार के पुनरावर्तक का उपयोग करके कार्यान्वित किया जा सकता है। यह ''SearchForElement'' को किसी भी कंटेनर पर उपयोग करने की अनुमति देता है जो आवश्यक प्रकार के पुनरावर्तक का समर्थन करता है। | ||
{{TOC limit|3}} | {{TOC limit|3}} | ||
Line 7: | Line 7: | ||
इटरेटर | इटरेटर | ||
<ref name="GoF">{{cite book|url=https://archive.org/details/designpatternsel00gamm/page/257|title=Design Patterns: Elements of Reusable Object-Oriented Software|author=Erich Gamma|last2=Richard Helm|last3=Ralph Johnson|last4=John Vlissides|publisher=Addison Wesley|year=1994|isbn=0-201-63361-2|pages=[https://archive.org/details/designpatternsel00gamm/page/257 257ff]|url-access=registration}}</ref> | <ref name="GoF">{{cite book|url=https://archive.org/details/designpatternsel00gamm/page/257|title=Design Patterns: Elements of Reusable Object-Oriented Software|author=Erich Gamma|last2=Richard Helm|last3=Ralph Johnson|last4=John Vlissides|publisher=Addison Wesley|year=1994|isbn=0-201-63361-2|pages=[https://archive.org/details/designpatternsel00gamm/page/257 257ff]|url-access=registration}}</ref> | ||
डिजाइन पैटर्न तेईस प्रसिद्ध में से | डिजाइन पैटर्न तेईस प्रसिद्ध में से है | ||
[[डिजाइन पैटर्न्स]] | [[डिजाइन पैटर्न्स]] | ||
यह वर्णन करता है कि लचीले और पुन: प्रयोज्य ऑब्जेक्ट-ओरिएंटेड सॉफ़्टवेयर को डिज़ाइन करने के लिए आवर्ती डिज़ाइन समस्याओं को कैसे हल किया जाए, अर्थात ऐसी वस्तुएँ जिन्हें लागू करना, बदलना, परीक्षण करना और पुन: उपयोग करना आसान हो। | यह वर्णन करता है कि लचीले और पुन: प्रयोज्य ऑब्जेक्ट-ओरिएंटेड सॉफ़्टवेयर को डिज़ाइन करने के लिए आवर्ती डिज़ाइन समस्याओं को कैसे हल किया जाए, अर्थात ऐसी वस्तुएँ जिन्हें लागू करना, बदलना, परीक्षण करना और पुन: उपयोग करना आसान हो। | ||
Line 21: | Line 21: | ||
=== इटरेटर डिज़ाइन पैटर्न किस समाधान का वर्णन करता है? === | === इटरेटर डिज़ाइन पैटर्न किस समाधान का वर्णन करता है? === | ||
* | * अलग (इटरेटर) ऑब्जेक्ट को परिभाषित करें जो समग्र ऑब्जेक्ट तक पहुँचने और ट्रैवर्सिंग को एनकैप्सुलेट करता है। | ||
* ग्राहक इसके प्रतिनिधित्व (डेटा संरचनाओं) को जानने के बिना | * ग्राहक इसके प्रतिनिधित्व (डेटा संरचनाओं) को जानने के बिना कुल तक पहुँचने और पार करने के लिए पुनरावर्तक का उपयोग करते हैं। | ||
अलग-अलग तरीकों से | अलग-अलग तरीकों से समुच्चय तक पहुँचने और पार करने के लिए अलग-अलग पुनरावृत्तियों का उपयोग किया जा सकता है। | ||
<br>नए पुनरावर्तकों को परिभाषित करके नई पहुंच और ट्रैवर्सल संचालन को स्वतंत्र रूप से परिभाषित किया जा सकता है। | <br>नए पुनरावर्तकों को परिभाषित करके नई पहुंच और ट्रैवर्सल संचालन को स्वतंत्र रूप से परिभाषित किया जा सकता है। | ||
Line 30: | Line 30: | ||
== परिभाषा == | == परिभाषा == | ||
Iterator पैटर्न का सार किसी समग्र वस्तु के तत्वों को उसके अंतर्निहित प्रतिनिधित्व को उजागर किए बिना क्रमिक रूप से एक्सेस करने का | Iterator पैटर्न का सार किसी समग्र वस्तु के तत्वों को उसके अंतर्निहित प्रतिनिधित्व को उजागर किए बिना क्रमिक रूप से एक्सेस करने का तरीका प्रदान करना है। .<ref>[[Design Patterns (book)|Gang Of Four]]</ref> | ||
Line 36: | Line 36: | ||
=== यूएमएल वर्ग और अनुक्रम आरेख === | === यूएमएल वर्ग और अनुक्रम आरेख === | ||
[[File:w3sDesign Iterator Design Pattern UML.jpg|frame|none|Iterator डिज़ाइन पैटर्न के लिए | [[File:w3sDesign Iterator Design Pattern UML.jpg|frame|none|Iterator डिज़ाइन पैटर्न के लिए नमूना UML वर्ग और अनुक्रम आरेख।<ref>{{cite web|title=इटरेटर डिजाइन पैटर्न - संरचना और सहयोग|url=http://w3sdesign.com/?gr=b04&ugr=struct|website=w3sDesign.com|access-date=2017-08-12}}</ref>]]उपरोक्त [[ एकीकृत मॉडलिंग भाषा ]] [[ वर्ग आरेख ]] में, <code>Client</code> वर्ग (1) को संदर्भित करता है <code>Aggregate</code> बनाने के लिए इंटरफ़ेस <code>Iterator</code> वस्तु (<code>createIterator()</code>) और (2) से <code>Iterator</code> ट्रैवर्सिंग के लिए इंटरफ़ेस <code>Aggregate</code> वस्तु (<code>next(),hasNext()</code>). <code>Iterator1</code> e> वर्ग लागू करता है <code>Iterator</code> इंटरफ़ेस का उपयोग करके <code>Aggregate1</code> कक्षा। | ||
एकीकृत मॉडलिंग भाषा [[अनुक्रम आरेख]] | एकीकृत मॉडलिंग भाषा [[अनुक्रम आरेख]] | ||
रन-टाइम इंटरैक्शन दिखाता है: <code>Client</code> ई> वस्तु कॉल <code>createIterator()</code> | रन-टाइम इंटरैक्शन दिखाता है: <code>Client</code> ई> वस्तु कॉल <code>createIterator()</code> पर <code>Aggregate1</code> वस्तु, जो बनाता है <code>Iterator1</code> वस्तु और उसे लौटाता है | ||
तक <code>Client</code>. <code>Client</code> e> तब उपयोग करता है <code>Iterator1</code> के तत्वों को पार करने के लिए <code>Aggregate1</code> वस्तु। | तक <code>Client</code>. <code>Client</code> e> तब उपयोग करता है <code>Iterator1</code> के तत्वों को पार करने के लिए <code>Aggregate1</code> वस्तु। | ||
Line 54: | Line 54: | ||
=== [[सी ++]] === | === [[सी ++]] === | ||
सी ++ उस भाषा में [[सूचक (कंप्यूटर प्रोग्रामिंग)]] के शब्दार्थ के साथ पुनरावृत्तियों को लागू करता है। सी ++ में, | सी ++ उस भाषा में [[सूचक (कंप्यूटर प्रोग्रामिंग)]] के शब्दार्थ के साथ पुनरावृत्तियों को लागू करता है। सी ++ में, वर्ग सभी पॉइंटर ऑपरेशंस को अधिभारित कर सकता है, इसलिए पुनरावर्तक को लागू किया जा सकता है जो सूचक की तरह अधिक या कम कार्य करता है, जो कि डीरेफरेंस, इंक्रीमेंट और डिक्रीमेंट के साथ पूरा होता है। इसका लाभ यह है कि सी ++ एल्गोरिदम जैसे <code>std::sort</code> सादे पुराने मेमोरी बफ़र्स पर तुरंत लागू किया जा सकता है, और यह कि सीखने के लिए कोई नया सिंटैक्स नहीं है। हालांकि, पुनरावर्तक को यह जानने की अनुमति देने के बजाय समानता के लिए परीक्षण करने के लिए अंत पुनरावर्तक की आवश्यकता होती है कि यह अंत तक पहुंच गया है। सी ++ भाषा में, हम कहते हैं कि इटरेटर इटरेटर [[अवधारणा (जेनेरिक प्रोग्रामिंग)]] का मॉडल करता है। | ||
यह C++ 11 कार्यान्वयन अध्याय सामान्यीकरण वेक्टर पर फिर से आधारित है।<ref>{{cite book |author=Bjarne Stroustrup |title=Programming: Principles and Practice using C++ |edition=2 |publisher=Addison Wesley |year=2014 |isbn=978-0-321-99278-9 |pages=729 ff.}}</ref> | यह C++ 11 कार्यान्वयन अध्याय सामान्यीकरण वेक्टर पर फिर से आधारित है।<ref>{{cite book |author=Bjarne Stroustrup |title=Programming: Principles and Practice using C++ |edition=2 |publisher=Addison Wesley |year=2014 |isbn=978-0-321-99278-9 |pages=729 ff.}}</ref> | ||
Line 113: | Line 113: | ||
1.21 | 1.21 | ||
4.84 | 4.84 | ||
'Std :: out_of_range' का | 'Std :: out_of_range' का उदाहरण फेंकने के बाद समाप्त हो गया | ||
क्या (): वेक्टर :: ऑपरेटर [] | क्या (): वेक्टर :: ऑपरेटर [] | ||
</वाक्यविन्यास हाइलाइट> | </वाक्यविन्यास हाइलाइट> |
Revision as of 17:36, 27 June 2023
ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग में, इटरेटर पैटर्न डिज़ाइन पैटर्न (कंप्यूटर साइंस) है जिसमें इटरेटर का उपयोग संग्रह (अमूर्त डेटा प्रकार) को पार करने और कंटेनर के तत्वों तक पहुंचने के लिए किया जाता है। पुनरावर्तक पैटर्न कंटेनरों से एल्गोरिदम को अलग करता है; कुछ मामलों में, एल्गोरिदम आवश्यक रूप से कंटेनर-विशिष्ट होते हैं और इस प्रकार उन्हें अलग नहीं किया जा सकता है।
उदाहरण के लिए, काल्पनिक कलन विधि SearchForElement को कंटेनर-विशिष्ट एल्गोरिथम के रूप में लागू करने के बजाय आमतौर पर निर्दिष्ट प्रकार के पुनरावर्तक का उपयोग करके कार्यान्वित किया जा सकता है। यह SearchForElement को किसी भी कंटेनर पर उपयोग करने की अनुमति देता है जो आवश्यक प्रकार के पुनरावर्तक का समर्थन करता है।
सिंहावलोकन
इटरेटर [1] डिजाइन पैटर्न तेईस प्रसिद्ध में से है डिजाइन पैटर्न्स यह वर्णन करता है कि लचीले और पुन: प्रयोज्य ऑब्जेक्ट-ओरिएंटेड सॉफ़्टवेयर को डिज़ाइन करने के लिए आवर्ती डिज़ाइन समस्याओं को कैसे हल किया जाए, अर्थात ऐसी वस्तुएँ जिन्हें लागू करना, बदलना, परीक्षण करना और पुन: उपयोग करना आसान हो।
इटरेटर डिज़ाइन पैटर्न किन समस्याओं को हल कर सकता है?
- समग्र वस्तु के तत्वों को इसके प्रतिनिधित्व (डेटा संरचनाओं) को उजागर किए बिना एक्सेस और ट्रैवर्स किया जाना चाहिए।
- नए ट्रैवर्सल ऑपरेशंस को इसके इंटरफ़ेस को बदले बिना कुल ऑब्जेक्ट के लिए परिभाषित किया जाना चाहिए।
एग्रीगेट इंटरफ़ेस में एक्सेस और ट्रैवर्सल ऑपरेशंस को परिभाषित करना अनम्य है क्योंकि यह एग्रीगेट को विशेष एक्सेस और ट्रैवर्सल ऑपरेशंस के लिए प्रतिबद्ध करता है और नए ऑपरेशंस को जोड़ना असंभव बनाता है बाद में समग्र इंटरफ़ेस को बदले बिना।
इटरेटर डिज़ाइन पैटर्न किस समाधान का वर्णन करता है?
- अलग (इटरेटर) ऑब्जेक्ट को परिभाषित करें जो समग्र ऑब्जेक्ट तक पहुँचने और ट्रैवर्सिंग को एनकैप्सुलेट करता है।
- ग्राहक इसके प्रतिनिधित्व (डेटा संरचनाओं) को जानने के बिना कुल तक पहुँचने और पार करने के लिए पुनरावर्तक का उपयोग करते हैं।
अलग-अलग तरीकों से समुच्चय तक पहुँचने और पार करने के लिए अलग-अलग पुनरावृत्तियों का उपयोग किया जा सकता है।
नए पुनरावर्तकों को परिभाषित करके नई पहुंच और ट्रैवर्सल संचालन को स्वतंत्र रूप से परिभाषित किया जा सकता है।
नीचे यूएमएल क्लास और सीक्वेंस डायग्राम भी देखें।
परिभाषा
Iterator पैटर्न का सार किसी समग्र वस्तु के तत्वों को उसके अंतर्निहित प्रतिनिधित्व को उजागर किए बिना क्रमिक रूप से एक्सेस करने का तरीका प्रदान करना है। .[3]
संरचना
यूएमएल वर्ग और अनुक्रम आरेख
उपरोक्त एकीकृत मॉडलिंग भाषा वर्ग आरेख में, Client
वर्ग (1) को संदर्भित करता है Aggregate
बनाने के लिए इंटरफ़ेस Iterator
वस्तु (createIterator()
) और (2) से Iterator
ट्रैवर्सिंग के लिए इंटरफ़ेस Aggregate
वस्तु (next(),hasNext()
). Iterator1
e> वर्ग लागू करता है Iterator
इंटरफ़ेस का उपयोग करके Aggregate1
कक्षा।
एकीकृत मॉडलिंग भाषा अनुक्रम आरेख
रन-टाइम इंटरैक्शन दिखाता है: Client
ई> वस्तु कॉल createIterator()
पर Aggregate1
वस्तु, जो बनाता है Iterator1
वस्तु और उसे लौटाता है
तक Client
. Client
e> तब उपयोग करता है Iterator1
के तत्वों को पार करने के लिए Aggregate1
वस्तु।
यूएमएल वर्ग आरेख
उदाहरण
कुछ भाषाएँ सिंटैक्स को मानकीकृत करती हैं। C++ और Python उल्लेखनीय उदाहरण हैं।
सी ++
सी ++ उस भाषा में सूचक (कंप्यूटर प्रोग्रामिंग) के शब्दार्थ के साथ पुनरावृत्तियों को लागू करता है। सी ++ में, वर्ग सभी पॉइंटर ऑपरेशंस को अधिभारित कर सकता है, इसलिए पुनरावर्तक को लागू किया जा सकता है जो सूचक की तरह अधिक या कम कार्य करता है, जो कि डीरेफरेंस, इंक्रीमेंट और डिक्रीमेंट के साथ पूरा होता है। इसका लाभ यह है कि सी ++ एल्गोरिदम जैसे std::sort
सादे पुराने मेमोरी बफ़र्स पर तुरंत लागू किया जा सकता है, और यह कि सीखने के लिए कोई नया सिंटैक्स नहीं है। हालांकि, पुनरावर्तक को यह जानने की अनुमति देने के बजाय समानता के लिए परीक्षण करने के लिए अंत पुनरावर्तक की आवश्यकता होती है कि यह अंत तक पहुंच गया है। सी ++ भाषा में, हम कहते हैं कि इटरेटर इटरेटर अवधारणा (जेनेरिक प्रोग्रामिंग) का मॉडल करता है।
यह C++ 11 कार्यान्वयन अध्याय सामान्यीकरण वेक्टर पर फिर से आधारित है।[5] <वाक्यविन्यास प्रकाश लैंग = सी ++>
- शामिल <iostream>
- शामिल करें
- शामिल करें <प्रारंभकर्ता_सूची>
वर्ग वेक्टर { जनता:
इटरेटर = डबल * का उपयोग करना; पुनरावर्तक प्रारंभ () {वापसी तत्व; } पुनरावर्तक अंत () {वापसी हाथ + sz; } वेक्टर (std::initializer_list<double> lst):elem(nullptr), sz(0) { एसजे = एलएसटी आकार (); एलएम = नया डबल [एसजेड]; डबल * पी = एलएम; for (auto i = lst.begin(); i != lst.end(); ++i, ++p) { *पी = *मैं; } } ~ वेक्टर () {हटाएं [] तत्व; } int आकार () कास्ट {वापसी sz; } डबल और ऑपरेटर [] (इंट एन) { if (n <0 || n >= sz) std::out_of_range(वेक्टर::ऑपरेटर[]); वापसी तत्व [एन]; } वेक्टर (स्थिरांक वेक्टर और) = हटाएं; // तीन का नियम वेक्टर और ऑपरेटर = (स्थिरांक वेक्टर और) = हटाएं;
निजी:
डबल * तत्व; इंट एसजेड;
};
मुख्य प्रवेश बिंदु() {
वेक्टर वी = {1.1*1.1, 2.2*2.2}; के लिए (स्थिरांक ऑटो और एक्स: वी) { एसटीडी :: अदालत << एक्स << '\n'; } for (auto i = v.begin(); i != v.end(); ++i) { एसटीडी :: अदालत << * मैं << '\n'; } for (auto i = 0; i <= v.size(); ++i) { एसटीडी :: अदालत << वी [i] << '\n'; }
} </वाक्यविन्यास हाइलाइट>
प्रोग्राम आउटपुट है
<वाक्यविन्यास प्रकाश लैंग = सी ++> 1.21 4.84 1.21 4.84 1.21 4.84 'Std :: out_of_range' का उदाहरण फेंकने के बाद समाप्त हो गया
क्या (): वेक्टर :: ऑपरेटर []
</वाक्यविन्यास हाइलाइट>
यह भी देखें
- समग्र पैटर्न
- कंटेनर (डेटा संरचना)
- डिजाइन पैटर्न (कंप्यूटर विज्ञान)
- इटरेटर
- पर्यवेक्षक पैटर्न
संदर्भ
- ↑ Erich Gamma; Richard Helm; Ralph Johnson; John Vlissides (1994). Design Patterns: Elements of Reusable Object-Oriented Software. Addison Wesley. pp. 257ff. ISBN 0-201-63361-2.
- ↑ "इटरेटर डिजाइन पैटर्न - समस्या, समाधान और प्रयोज्यता". w3sDesign.com. Retrieved 2017-08-12.
- ↑ Gang Of Four
- ↑ "इटरेटर डिजाइन पैटर्न - संरचना और सहयोग". w3sDesign.com. Retrieved 2017-08-12.
- ↑ Bjarne Stroustrup (2014). Programming: Principles and Practice using C++ (2 ed.). Addison Wesley. pp. 729 ff. ISBN 978-0-321-99278-9.