1.1 पैटर्न का परिचय

जैसा कि पहले उल्लेख किया गया है, एक प्रोग्रामर अपने मॉडल को डिजाइन करके एक कार्यक्रम पर काम करना शुरू करता है: उन संस्थाओं की सूची संकलित करता है जिन पर कार्यक्रम संचालित होगा। और कार्यक्रम में जितनी अधिक संस्थाएँ होंगी, कार्यक्रम उतना ही जटिल होगा।

इसलिए, कार्यक्रम की जटिलता को कम करने के लिए, वे वस्तुओं की बातचीत को मानकीकृत करने का प्रयास करते हैं। और यहीं पर डिज़ाइन पैटर्न या डिज़ाइन पैटर्न प्रोग्रामर की बहुत मदद करते हैं । अंग्रेजी डिजाइन पैटर्न से ।

महत्वपूर्ण! रूसी में, डिज़ाइन शब्द का अर्थ आमतौर पर ग्राफिक डिज़ाइन होता है, अंग्रेजी में ऐसा नहीं है। अंग्रेजी शब्द डिजाइन "डिजाइन" और / या "डिवाइस" शब्द के अर्थ के करीब है। उदाहरण के लिए, किसी इंजन का डिज़ाइन उसका स्वरूप नहीं है, बल्कि उसकी आंतरिक संरचना है।

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

तो यह डिज़ाइन पैटर्न क्या है? सबसे पहले, एक डिज़ाइन पैटर्न एक मानक समस्या का एक मानक समाधान है । एक अच्छा, प्रभावी और समय-परीक्षणित समाधान।

मान लीजिए कि आपको एक साइकिल डिजाइन करने के लिए कहा गया है, आप इसे दो पहिये, तीन या पांच भी बना सकते हैं। तो वैसे, डिजाइन के भोर में, यह था। लेकिन समय-परीक्षणित दृष्टिकोण दो पहिए हैं। लेकिन वर्तमान स्पष्ट दृष्टिकोण दर्द और गलतियों से गुजरा:

आमतौर पर, एक टेम्पलेट एक पूर्ण समाधान नहीं है जिसे सीधे कोड में परिवर्तित किया जा सकता है, यह किसी समस्या के अच्छे समाधान का एक उदाहरण है जिसका उपयोग विभिन्न स्थितियों में किया जा सकता है।

ऑब्जेक्ट-ओरिएंटेड पैटर्न कक्षाओं या वस्तुओं के बीच संबंध और बातचीत दिखाते हैं , यह निर्दिष्ट किए बिना कि कौन से अंतिम वर्ग या एप्लिकेशन ऑब्जेक्ट का उपयोग किया जाएगा।

1.2 डिजाइन पैटर्न का इतिहास

70 के दशक में, प्रोग्रामरों को बड़े कार्यक्रमों को विकसित करने की आवश्यकता का सामना करना पड़ा, जिन पर संपूर्ण विकास टीमों द्वारा काम किया जाना था। कार्य को व्यवस्थित करने के विभिन्न तरीकों की कोशिश की गई, लेकिन निर्माण उद्योग ने विकास को सबसे अधिक प्रभावित किया।

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

और जैसा कि आप अनुमान लगा सकते हैं, डिजाइन पैटर्न का विचार भी निर्माण उद्योग से लिया गया था। पैटर्न की अवधारणा को सबसे पहले क्रिस्टोफर अलेक्जेंडर ने द पैटर्न लैंग्वेज में वर्णित किया था। शहरों। इमारत। निर्माण"। इस पुस्तक में शहर के डिजाइन की प्रक्रियाओं का वर्णन करने के लिए एक विशेष भाषा, पैटर्न का उपयोग किया गया है।

निर्माण में पैटर्न विशिष्ट समय-परीक्षणित निर्णयों का वर्णन करते हैं: कितनी ऊंची खिड़कियां होनी चाहिए, इमारत में कितनी मंजिलें होनी चाहिए, पेड़ों और लॉन के लिए माइक्रोडिस्ट्रिक्ट में कितना क्षेत्र आवंटित किया जाना चाहिए।

इसलिए, यह आश्चर्य की बात नहीं है कि 1994 में "ऑब्जेक्ट-ओरिएंटेड डिज़ाइन की तकनीक" पुस्तक। डिज़ाइन पैटर्न", जिसमें 23 पैटर्न शामिल हैं जो ऑब्जेक्ट-ओरिएंटेड डिज़ाइन की विभिन्न समस्याओं को हल करते हैं।

पुस्तक 4 लेखकों द्वारा लिखी गई थी: एरिच गामा, रिचर्ड हेल्म, राल्फ जॉनसन और जॉन व्लिससाइड्स। पुस्तक का शीर्षक किसी के लिए भी याद रखने के लिए बहुत लंबा था। इसलिए, जल्द ही हर कोई इसे "चार के गिरोह की किताब", यानी "चार के गिरोह की एक किताब" और फिर "गोफ बुक" भी कहने लगा।

और तब से, अन्य डिज़ाइन पैटर्न खोजे गए हैं। प्रोग्रामिंग के सभी क्षेत्रों में "पैटर्न" दृष्टिकोण लोकप्रिय हो गया है, इसलिए अब आप ऑब्जेक्ट डिज़ाइन के बाहर सभी प्रकार के पैटर्न पा सकते हैं।

महत्वपूर्ण! पैटर्न कुछ सुपर-मूल समाधान नहीं हैं, बल्कि, इसके विपरीत, एक ही समस्या के लिए अक्सर सामना किए जाने वाले विशिष्ट समाधान हैं। अच्छा सिद्ध उपाय।

1.3 पैटर्न की सूची

कई प्रोग्रामरों ने अपने पूरे जीवन में एक भी पैटर्न नहीं सीखा है, जो उन्हें उनका उपयोग करने से नहीं रोकता है। जैसा कि हमने पहले कहा, पैटर्न अच्छे समय-परीक्षणित समाधान हैं, और यदि प्रोग्रामर मूर्ख नहीं है, तो अनुभव के साथ वह स्वयं ऐसे समाधान ढूंढता है।

लेकिन दर्जनों परीक्षणों और त्रुटियों के माध्यम से, इष्टतम समाधान क्यों आते हैं जब ऐसे लोग हैं जो पहले से ही इस तरह से जा चुके हैं और अपने अनुभव और जीवन ज्ञान की सर्वोत्कृष्टता के साथ किताबें लिख चुके हैं?

आप रिंच से कील ठोक सकते हैं, लेकिन क्यों? यदि आप कड़ी मेहनत करते हैं तो आप ड्रिल का भी उपयोग कर सकते हैं। लेकिन साधन का एक अच्छा सचेत अधिकार ठीक वही है जो एक पेशेवर को एक शौकिया से अलग करता है। और पेशेवर जानता है कि ड्रिल की मुख्य विशेषता इसमें बिल्कुल नहीं है। तो, आपको पैटर्न जानने की आवश्यकता क्यों है?

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

पैटर्न क्या हैं?

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

सबसे निम्न स्तर और सरल पैटर्न मुहावरे हैं। वे सार्वभौमिक नहीं हैं, क्योंकि वे केवल एक प्रोग्रामिंग भाषा के ढांचे के भीतर ही लागू होते हैं।

सबसे बहुमुखी वास्तुशिल्प पैटर्न हैं जिन्हें लगभग किसी भी भाषा में लागू किया जा सकता है। उन्हें पूरे कार्यक्रम को डिजाइन करने की जरूरत है, न कि इसके अलग-अलग तत्वों की।

लेकिन मुख्य बात यह है कि पैटर्न उद्देश्य में भिन्न होते हैं। जिन पैटर्नों से हम परिचित होंगे उन्हें तीन मुख्य समूहों में विभाजित किया जा सकता है:

  • निर्माण पैटर्न कार्यक्रम में अनावश्यक निर्भरताओं को पेश किए बिना वस्तुओं के लचीले निर्माण का ख्याल रखता है।
  • संरचनात्मक पैटर्न वस्तुओं के बीच संबंध बनाने के विभिन्न तरीके दिखाते हैं।
  • व्यवहार पैटर्न वस्तुओं के बीच कुशल संचार का ख्याल रखते हैं।

1.4 यूएमएल का परिचय

आइए उन्हीं 23 प्रतिमानों को देखकर आरंभ करें जिनका वर्णन गैंग ऑफ फोर पुस्तक में किया गया था। नौसिखिए प्रोग्रामर के लिए भी दोनों पैटर्न और उनके नाम परिचित चीजें हैं। मैं आपको उनसे मिलवाऊंगा, लेकिन मैं पैटर्न के बारे में उसी किताब को पढ़ने की जोरदार सलाह देता हूं।

डिज़ाइन पैटर्न किसी विशिष्ट प्रोग्रामिंग भाषा से बंधे नहीं हैं, इसलिए आमतौर पर यूएमएल का उपयोग उनका वर्णन करने के लिए किया जाता है। यह 20 साल पहले बहुत लोकप्रिय था, लेकिन अब भी कभी-कभी इसका इस्तेमाल होता है। और वैसे, पैटर्न का विवरण केवल वह स्थान है जहां यूएमएल का उपयोग मानक है।

यूएमएल के साथ, आप विभिन्न संस्थाओं के बीच संबंधों का वर्णन कर सकते हैं। हमारे मामले में, ये वस्तुएं और वर्ग हैं।

वर्गों के बीच संबंधों को चार प्रकार के तीरों द्वारा वर्णित किया गया है:

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

वास्तव में, यहाँ सब कुछ बहुत सरल है। अंतिम तीर का वास्तव में मतलब है कि एक वर्ग दूसरे वर्ग से विरासत में मिला है। और पहला और दूसरा तीर यह है कि एक वस्तु दूसरी वस्तु के लिए एक कड़ी को संग्रहीत करती है। और यह सब है।

यदि लिंक हीरा काला है, तो लिंक कमजोर है: वस्तुएं एक दूसरे के बिना मौजूद हो सकती हैं। यदि हीरा सफेद है, तो वस्तुएँ दृढ़ता से संबंधित हैं, जैसे कि एक वर्ग HttpRequestऔर उसका उप वर्ग HttpRequest.Builder

1.5 पैटर्न की सूची

पैटर्न के प्रकार विभिन्न रंगों और अक्षरों द्वारा निरूपित किए जाएंगे:

बी- व्यवहार (व्यवहार);

सी- उत्पन्न करना (रचनात्मक);

एस- संरचनात्मक (संरचनात्मक)।

और अंत में, 23 डिज़ाइन पैटर्न की एक सूची:

सी- सार फैक्टरी

एस- एडेप्टर

एस- पुल

सी- बिल्डर

बी- जिम्मेदारियों की श्रृंखला

बी- टीम

एस- लिंकर

एस- डेकोरेटर

एस- मुखौटा

सी- कारखाना विधि

एस- अवसरवादी

बी- दुभाषिया

बी- इटरेटर

बी- मध्यस्थ

बी- रखवाला

सी- प्रोटोटाइप

एस- प्रॉक्सी

बी- देखने वाला

सी- कुंवारा

बी- राज्य

बी- रणनीति

बी- टेम्पलेट विधि

बी- आगंतुक