OOAD - ऑब्जेक्ट ओरिएंटेड डिज़ाइन
विश्लेषण चरण के बाद, वैचारिक मॉडल को ऑब्जेक्ट-ओरिएंटेड डिज़ाइन (OOD) का उपयोग करके ऑब्जेक्ट-ओरिएंटेड मॉडल में और विकसित किया जाता है। OOD में, विश्लेषण मॉडल में प्रौद्योगिकी-स्वतंत्र अवधारणाओं को कक्षाएं लागू करने पर मैप किया जाता है, बाधाओं की पहचान की जाती है, और इंटरफेस डिज़ाइन किए जाते हैं, जिसके परिणामस्वरूप समाधान डोमेन के लिए एक मॉडल होता है। संक्षेप में, विस्तृत विवरण का निर्माण यह निर्दिष्ट करने के लिए किया जाता है कि सिस्टम को कंक्रीट प्रौद्योगिकियों पर कैसे बनाया जाना है
ऑब्जेक्ट-ओरिएंटेड डिज़ाइन के चरणों की पहचान इस प्रकार की जा सकती है -
- प्रणाली के संदर्भ की परिभाषा
- डिजाइनिंग सिस्टम आर्किटेक्चर
- प्रणाली में वस्तुओं की पहचान
- डिजाइन मॉडल का निर्माण
- ऑब्जेक्ट इंटरफेस की विशिष्टता
प्रणाली की रूपरेखा
ऑब्जेक्ट-ओरिएंटेड सिस्टम डिज़ाइन में सिस्टम के आर्किटेक्चर को डिज़ाइन करने के बाद सिस्टम के संदर्भ को परिभाषित करना शामिल है।
Context- एक प्रणाली के संदर्भ में एक स्थिर और एक गतिशील हिस्सा है। सिस्टम का स्थैतिक संदर्भ पूरे सिस्टम के एक सरल ब्लॉक आरेख का उपयोग करके बनाया गया है जो उपतंत्रों के पदानुक्रम में विस्तारित होता है। सबसिस्टम मॉडल को यूएमएल पैकेज द्वारा दर्शाया गया है। गतिशील संदर्भ बताता है कि सिस्टम अपने पर्यावरण के साथ कैसे संपर्क करता है। इसका उपयोग करके मॉडलिंग की जाती हैuse case diagrams।
System Architecture- सिस्टम आर्किटेक्चर को सिस्टम के संदर्भ के आधार पर आर्किटेक्चरल डिज़ाइन के सिद्धांतों के साथ-साथ डोमेन ज्ञान के आधार पर डिज़ाइन किया गया है। आमतौर पर, एक सिस्टम को परतों में विभाजित किया जाता है और सबसिस्टम बनाने के लिए प्रत्येक परत को विघटित किया जाता है।
ऑब्जेक्ट ओरिएंटेड अपघटन
विघटन का अर्थ है एक बड़ी जटिल प्रणाली को छोटे-छोटे घटकों के पदानुक्रम में विभाजित करना, कम जटिलताओं के साथ विभाजित करना और जीतना। सिस्टम के प्रत्येक प्रमुख घटक को एक सबसिस्टम कहा जाता है। वस्तु-उन्मुख अपघटन एक प्रणाली में व्यक्तिगत स्वायत्त वस्तुओं और इन वस्तुओं के बीच संचार की पहचान करता है।
अपघटन के फायदे हैं -
अलग-अलग घटक कम जटिलता के होते हैं, और इसलिए अधिक समझने योग्य और प्रबंधनीय होते हैं।
यह विशेष कौशल वाले कार्यबल के विभाजन को सक्षम बनाता है।
यह उप-प्रणालियों को अन्य उप-प्रणालियों को प्रभावित किए बिना प्रतिस्थापित या संशोधित करने की अनुमति देता है।
कंसीडर की पहचान
Concurrency एक ही समय में एक से अधिक ऑब्जेक्ट प्राप्त करने की अनुमति देता है और एक से अधिक गतिविधियों को एक साथ निष्पादित किया जाता है। Concurrency की पहचान और गतिशील मॉडल में प्रतिनिधित्व किया है।
समवर्ती सक्षम करने के लिए, प्रत्येक समवर्ती तत्व को नियंत्रण का एक अलग थ्रेड सौंपा गया है। यदि कंसीलर ऑब्जेक्ट स्तर पर है, तो दो समवर्ती वस्तुओं को नियंत्रण के दो अलग-अलग थ्रेड असाइन किए जाते हैं। यदि किसी एकल वस्तु के दो संचालन प्रकृति में समवर्ती हैं, तो वह वस्तु विभिन्न थ्रेड्स के बीच विभाजित होती है।
कंसीडर डेटा अखंडता, गतिरोध और भुखमरी की समस्याओं से जुड़ा हुआ है। इसलिए जब भी आवश्यक हो, एक स्पष्ट रणनीति बनाई जानी चाहिए। इसके अलावा, संगामिति को डिजाइन चरण में ही पहचाना जाना चाहिए, और कार्यान्वयन चरण के लिए नहीं छोड़ा जा सकता।
पैटर्न की पहचान करना
अनुप्रयोगों को डिजाइन करते समय, कुछ श्रेणियों की समस्याओं के लिए कुछ स्वीकृत समाधानों को अपनाया जाता है। ये डिजाइन के पैटर्न हैं। एक पैटर्न को बिल्डिंग ब्लॉक्स के एक दस्तावेज सेट के रूप में परिभाषित किया जा सकता है जिसका उपयोग कुछ प्रकार के अनुप्रयोग विकास समस्याओं में किया जा सकता है।
आमतौर पर इस्तेमाल किए जाने वाले कुछ डिज़ाइन पैटर्न हैं
- फाकेड पैटर्न
- मॉडल दृश्य पृथक्करण पैटर्न
- ऑब्जर्वर पैटर्न
- मॉडल दृश्य नियंत्रक पैटर्न
- सदस्यता पैटर्न प्रकाशित करें
- प्रॉक्सी पैटर्न
घटनाओं को नियंत्रित करना
सिस्टम डिजाइन के दौरान, सिस्टम की वस्तुओं में होने वाली घटनाओं को पहचानने और उचित तरीके से निपटाए जाने की आवश्यकता होती है।
एक घटना एक महत्वपूर्ण घटना का एक विनिर्देश है जिसका समय और स्थान में स्थान है।
चार प्रकार की घटनाएँ होती हैं जिन्हें मॉडल किया जा सकता है, अर्थात् -
Signal Event - एक नामित वस्तु को एक वस्तु द्वारा फेंक दिया जाता है और दूसरी वस्तु द्वारा पकड़ा जाता है।
Call Event - एक ऑपरेशन के प्रेषण का एक तुल्यकालिक घटना।
Time Event - समय बीतने का प्रतिनिधित्व करने वाली घटना।
Change Event - राज्य में परिवर्तन का प्रतिनिधित्व करने वाली घटना।
बाउंड्री की स्थिति को संभालना
सिस्टम डिज़ाइन चरण को एक सबसिस्टम के साथ-साथ सिस्टम के आरंभ और समाप्ति को संबोधित करने की आवश्यकता है। प्रलेखित विभिन्न पहलू निम्नानुसार हैं -
सिस्टम का स्टार्ट-अप, अर्थात, गैर-आरंभिक अवस्था से स्थिर अवस्था में सिस्टम का संक्रमण।
सिस्टम की समाप्ति, अर्थात, सभी चल रहे थ्रेड्स को बंद करना, संसाधनों की सफाई और भेजे जाने वाले संदेश।
सिस्टम का प्रारंभिक विन्यास और जरूरत पड़ने पर सिस्टम का पुन: संयोजन।
सिस्टम की असफल विफलता या अवांछित समाप्ति।
सीमा की स्थिति का उपयोग सीमा मामलों के उपयोग से किया जाता है।
ऑब्जेक्ट डिज़ाइन
उपतंत्रों के पदानुक्रम को विकसित करने के बाद, सिस्टम में वस्तुओं की पहचान की जाती है और उनके विवरणों को डिजाइन किया जाता है। यहां, डिज़ाइनर ने सिस्टम डिज़ाइन के दौरान चुनी गई रणनीति का विवरण दिया। जोर कंप्यूटर अवधारणाओं की ओर अनुप्रयोग डोमेन अवधारणाओं से हट जाता है। विश्लेषण के दौरान पहचानी गई वस्तुओं को क्रियान्वयन के समय, स्मृति की खपत और समग्र लागत को कम करने के उद्देश्य से लागू किया जाता है।
ऑब्जेक्ट डिज़ाइन में निम्नलिखित चरण शामिल हैं -
- वस्तु पहचान
- ऑब्जेक्ट प्रतिनिधित्व, यानी, डिजाइन मॉडल का निर्माण
- संचालन का वर्गीकरण
- एल्गोरिदम डिजाइन
- रिश्तों का डिजाइन
- बाहरी बातचीत के लिए नियंत्रण का कार्यान्वयन
- पैकेज कक्षाएं और मॉड्यूल में संघ
वस्तु पहचान
ऑब्जेक्ट डिज़ाइन का पहला चरण ऑब्जेक्ट आइडेंटिफिकेशन है। ऑब्जेक्ट-ओरिएंटेड विश्लेषण चरणों में पहचाने गए ऑब्जेक्ट को कक्षाओं में वर्गीकृत किया जाता है और परिष्कृत किया जाता है ताकि वे वास्तविक कार्यान्वयन के लिए उपयुक्त हों।
इस चरण के कार्य हैं -
प्रत्येक सबसिस्टम या पैकेज में कक्षाओं को पहचानना और परिष्कृत करना
कक्षाओं के बीच लिंक और संघों को परिभाषित करना
कक्षाओं के बीच पदानुक्रमित संघों को डिजाइन करना, अर्थात, सामान्यीकरण / विशेषज्ञता और विरासत
डिजाइनिंग एकत्रीकरण
वस्तु प्रतिनिधित्व
एक बार कक्षाओं की पहचान हो जाने के बाद, उन्हें ऑब्जेक्ट मॉडलिंग तकनीकों का उपयोग करके प्रतिनिधित्व करने की आवश्यकता होती है। इस चरण में अनिवार्य रूप से यूएमएल आरेखों का निर्माण शामिल है।
दो प्रकार के डिज़ाइन मॉडल हैं जिनका उत्पादन करने की आवश्यकता है -
Static Models - क्लास आरेखों और ऑब्जेक्ट आरेखों का उपयोग करके सिस्टम की स्थिर संरचना का वर्णन करना।
Dynamic Models - एक प्रणाली की गतिशील संरचना का वर्णन करने के लिए और इंटरेक्शन आरेख और राज्य-चार्ट आरेखों का उपयोग करके कक्षाओं के बीच बातचीत को दिखाना।
संचालन का वर्गीकरण
इस चरण में, ऑब्जेक्ट पर किए जाने वाले ऑपरेशन को OOA चरण में विकसित तीन मॉडल, अर्थात्, ऑब्जेक्ट मॉडल, डायनामिक मॉडल और कार्यात्मक मॉडल के संयोजन से परिभाषित किया जाता है। एक ऑपरेशन निर्दिष्ट करता है कि क्या किया जाना चाहिए और यह नहीं कि इसे कैसे किया जाना चाहिए।
संचालन के संबंध में निम्नलिखित कार्य किए जाते हैं -
सिस्टम में प्रत्येक वस्तु का राज्य संक्रमण आरेख विकसित किया जाता है।
ऑब्जेक्ट द्वारा प्राप्त घटनाओं के लिए संचालन को परिभाषित किया गया है।
ऐसे मामले जिनमें एक घटना एक ही या अलग-अलग वस्तुओं में अन्य घटनाओं को ट्रिगर करती है।
कार्यों के भीतर उप-संचालन की पहचान की जाती है।
मुख्य क्रियाओं का विस्तार डेटा प्रवाह आरेखों तक होता है।
एल्गोरिदम डिजाइन
ऑब्जेक्ट्स के संचालन को एल्गोरिदम का उपयोग करके परिभाषित किया गया है। एक एल्गोरिथ्म एक चरणबद्ध प्रक्रिया है जो एक ऑपरेशन में रखी गई समस्या को हल करती है। एल्गोरिदम ध्यान केंद्रित करता है कि यह कैसे किया जाना है।
किसी दिए गए ऑपरेशन के लिए एक से अधिक एल्गोरिथ्म हो सकते हैं। वैकल्पिक एल्गोरिदम की पहचान हो जाने के बाद, दिए गए समस्या डोमेन के लिए इष्टतम एल्गोरिदम का चयन किया जाता है। इष्टतम एल्गोरिथ्म चुनने के लिए मैट्रिक्स हैं -
Computational Complexity - जटिलता समय और स्मृति आवश्यकताओं के संदर्भ में एक एल्गोरिथ्म की दक्षता निर्धारित करती है।
Flexibility - लचीलापन यह निर्धारित करता है कि विभिन्न वातावरणों में उपयुक्तता के नुकसान के बिना चुने हुए एल्गोरिथ्म को उपयुक्त रूप से लागू किया जा सकता है या नहीं।
Understandability - यह निर्धारित करता है कि क्या चुने हुए एल्गोरिदम को समझना और लागू करना आसान है।
रिश्तों का डिजाइन
ऑब्जेक्ट डिज़ाइन चरण के दौरान रिश्तों को लागू करने की रणनीति को चाक-चौबंद करने की आवश्यकता है। संबोधित किए जाने वाले मुख्य संबंध संघों, एकत्रीकरण और विरासत में शामिल हैं।
संघों के संबंध में डिजाइनर को निम्न कार्य करना चाहिए -
यह पहचानें कि क्या कोई एसोसिएशन यूनिडायरेक्शनल या द्विदिश है।
संघों के मार्ग का विश्लेषण करें और यदि आवश्यक हो तो उन्हें अपडेट करें।
कई-कई रिश्तों के मामले में संघों को एक अलग वस्तु के रूप में लागू करें; या एक-से-एक या एक-से-कई संबंधों के मामले में अन्य ऑब्जेक्ट के लिंक के रूप में।
विरासत के बारे में, डिजाइनर को निम्नलिखित काम करने चाहिए -
कक्षाओं और उनके संघों को समायोजित करें।
अमूर्त वर्गों को पहचानें।
प्रावधान करें ताकि जरूरत पड़ने पर व्यवहार साझा किए जाएं।
नियंत्रण का कार्यान्वयन
ऑब्जेक्ट डिजाइनर राज्य-चार्ट मॉडल की रणनीति में शोधन शामिल कर सकता है। सिस्टम डिजाइन में, गतिशील मॉडल को साकार करने के लिए एक बुनियादी रणनीति बनाई गई है। ऑब्जेक्ट डिज़ाइन के दौरान, यह रणनीति उपयुक्त कार्यान्वयन के लिए उपयुक्त है।
गतिशील मॉडल के कार्यान्वयन के लिए दृष्टिकोण हैं -
Represent State as a Location within a Program- यह पारंपरिक प्रक्रिया संचालित दृष्टिकोण है जिससे नियंत्रण का स्थान कार्यक्रम की स्थिति को परिभाषित करता है। एक परिमित राज्य मशीन को एक कार्यक्रम के रूप में लागू किया जा सकता है। एक संक्रमण एक इनपुट स्टेटमेंट बनाता है, मुख्य नियंत्रण पथ निर्देशों का अनुक्रम बनाता है, शाखाएं स्थितियों का निर्माण करती हैं, और पीछे के मार्ग छोरों या पुनरावृत्तियों का निर्माण करते हैं।
State Machine Engine- यह दृष्टिकोण सीधे राज्य मशीन इंजन वर्ग के माध्यम से एक राज्य मशीन का प्रतिनिधित्व करता है। यह वर्ग एप्लिकेशन द्वारा प्रदान किए गए संक्रमण और कार्यों के एक सेट के माध्यम से राज्य मशीन को निष्पादित करता है।
Control as Concurrent Tasks- इस दृष्टिकोण में, एक ऑब्जेक्ट को प्रोग्रामिंग भाषा या ऑपरेटिंग सिस्टम में एक कार्य के रूप में लागू किया जाता है। यहां, एक घटना को इंटर-टास्क कॉल के रूप में कार्यान्वित किया जाता है। यह वास्तविक वस्तुओं की अंतर्निहित संगामिति को संरक्षित करता है।
पैकेजिंग कक्षाएं
किसी भी बड़ी परियोजना में, मॉड्यूल या पैकेज में कार्यान्वयन का सावधानीपूर्वक विभाजन महत्वपूर्ण है। ऑब्जेक्ट डिज़ाइन के दौरान, कई समूह और ऑब्जेक्ट को एक प्रोजेक्ट पर सहकारी रूप से कार्य करने के लिए कई समूहों को सक्षम करने के लिए पैकेज में वर्गीकृत किया जाता है।
पैकेजिंग के विभिन्न पहलू हैं -
Hiding Internal Information from Outside View - यह एक वर्ग को "ब्लैक बॉक्स" के रूप में देखा जा सकता है और कोड को संशोधित करने के लिए वर्ग के किसी भी ग्राहक की आवश्यकता के बिना वर्ग कार्यान्वयन को बदलने की अनुमति देता है।
Coherence of Elements - एक तत्व, जैसे कि एक वर्ग, एक ऑपरेशन, या एक मॉड्यूल, सुसंगत है यदि यह एक सुसंगत योजना पर आयोजित किया जाता है और इसके सभी भाग आंतरिक रूप से संबंधित होते हैं ताकि वे एक सामान्य लक्ष्य की सेवा करें।
Construction of Physical Modules - भौतिक मॉड्यूल का निर्माण करते समय निम्नलिखित दिशानिर्देश मदद करते हैं -
एक मॉड्यूल में कक्षाएं एक ही समग्र वस्तु में समान चीजों या घटकों का प्रतिनिधित्व करना चाहिए।
समान रूप से कनेक्टेड कक्षाएं एक ही मॉड्यूल में होनी चाहिए।
असंबद्ध या कमजोर रूप से जुड़े वर्गों को अलग-अलग मॉड्यूल में रखा जाना चाहिए।
मॉड्यूल में अच्छा सामंजस्य होना चाहिए, अर्थात इसके घटकों के बीच उच्च सहयोग।
एक मॉड्यूल में अन्य मॉड्यूल के साथ कम युग्मन होना चाहिए, अर्थात, मॉड्यूल के बीच बातचीत या अन्योन्याश्रय न्यूनतम होना चाहिए।
डिजाइन अनुकूलन
विश्लेषण मॉडल सिस्टम के बारे में तार्किक जानकारी को कैप्चर करता है, जबकि डिजाइन मॉडल कुशल सूचना एक्सेस का समर्थन करने के लिए विवरण जोड़ता है। एक डिजाइन लागू होने से पहले, इसे लागू किया जाना चाहिए ताकि कार्यान्वयन को अधिक कुशल बनाया जा सके। अनुकूलन का उद्देश्य समय, स्थान और अन्य मैट्रिक्स के संदर्भ में लागत को कम करना है।
हालांकि, डिजाइन अनुकूलन अतिरिक्त नहीं होना चाहिए, क्योंकि कार्यान्वयन में आसानी, स्थिरता और विस्तारशीलता भी महत्वपूर्ण चिंताएं हैं। यह अक्सर देखा जाता है कि एक पूरी तरह से अनुकूलित डिजाइन अधिक कुशल है लेकिन कम पठनीय और पुन: प्रयोज्य है। इसलिए डिजाइनर को दोनों के बीच संतुलन बनाना होगा।
डिज़ाइन ऑप्टिमाइज़ेशन के लिए की जाने वाली विभिन्न चीज़ें हैं -
- निरर्थक संघों को जोड़ें
- गैर-अनुपयोगी संघों को छोड़ें
- एल्गोरिदम का अनुकूलन
- जटिल अभिव्यक्तियों की पुन: गणना से बचने के लिए व्युत्पन्न विशेषताएँ सहेजें
निरर्थक संघों का जोड़
डिज़ाइन ऑप्टिमाइज़ेशन के दौरान, यह जांचा जाता है कि क्या नए संघों तक पहुँच प्राप्त करने की लागत कम हो सकती है। हालांकि ये निरर्थक संघ कोई जानकारी नहीं जोड़ सकते हैं, लेकिन वे समग्र मॉडल की दक्षता बढ़ा सकते हैं।
गैर-उपयोग योग्य संघों का प्रवेश
बहुत से संघों की उपस्थिति एक प्रणाली को अनिर्णायक बना सकती है और इसलिए प्रणाली की समग्र दक्षता को कम करती है। इसलिए, अनुकूलन के दौरान, सभी गैर-उपयोग योग्य संघों को हटा दिया जाता है।
एल्गोरिदम का अनुकूलन
ऑब्जेक्ट-ओरिएंटेड सिस्टम में, डेटा संरचना और एल्गोरिदम का अनुकूलन एक सहयोगात्मक तरीके से किया जाता है। एक बार जब क्लास डिजाइन हो जाता है, तो संचालन और एल्गोरिदम को अनुकूलित करने की आवश्यकता होती है।
एल्गोरिदम का अनुकूलन किसके द्वारा प्राप्त किया जाता है -
- कम्प्यूटेशनल कार्यों के क्रम की पुनर्व्यवस्था
- कार्यात्मक मॉडल में रखी गई छोरों के निष्पादन के क्रम का उलटा
- एल्गोरिथ्म के भीतर मृत रास्तों को हटाना
सहेजा जा रहा है और व्युत्पन्न गुणों का भंडारण
व्युत्पन्न विशेषताएँ वे विशेषताएँ हैं जिनके मान की गणना अन्य विशेषताओं (आधार विशेषताओं) के एक फ़ंक्शन के रूप में की जाती है। व्युत्पन्न विशेषताओं के मूल्यों की पुन: गणना हर बार आवश्यक होने पर एक समय लेने वाली प्रक्रिया है। इससे बचने के लिए, मूल्यों की गणना की जा सकती है और उनके संगृहीत रूपों में संग्रहित किया जा सकता है।
हालाँकि, यह अद्यतन विसंगतियों को रोक सकता है, अर्थात, आधार विशेषताओं के मूल्यों में एक परिवर्तन व्युत्पन्न विशेषताओं के मूल्यों में कोई संगत परिवर्तन नहीं है। इससे बचने के लिए, निम्नलिखित कदम उठाए जाते हैं -
आधार विशेषता मान के प्रत्येक अद्यतन के साथ, व्युत्पन्न विशेषता भी फिर से गणना की जाती है।
व्युत्पन्न सभी विशेषताओं को प्रत्येक अद्यतन के बजाय एक समूह में समय-समय पर पुन: गणना और अद्यतन किया जाता है।
डिजाइन प्रलेखन
प्रलेखन किसी भी सॉफ्टवेयर विकास प्रक्रिया का एक अनिवार्य हिस्सा है जो सॉफ्टवेयर बनाने की प्रक्रिया को रिकॉर्ड करता है। डिज़ाइन के निर्णयों को किसी भी गैर-तुच्छ सॉफ़्टवेयर सिस्टम के लिए डिज़ाइन किया जाना चाहिए ताकि दूसरों को डिज़ाइन प्रेषित किया जा सके।
उपयोग क्षेत्र
हालांकि एक माध्यमिक उत्पाद, एक अच्छा प्रलेखन अपरिहार्य है, विशेष रूप से निम्नलिखित क्षेत्रों में -
- डिजाइनिंग सॉफ्टवेयर में जो कई डेवलपर्स द्वारा विकसित किया जा रहा है
- सॉफ्टवेयर सॉफ्टवेयर विकास रणनीतियों में
- एक सॉफ्टवेयर प्रोजेक्ट के बाद के संस्करणों को विकसित करने में
- एक सॉफ्टवेयर का मूल्यांकन करने के लिए
- परीक्षण की स्थितियों और क्षेत्रों को खोजने के लिए
- सॉफ्टवेयर के रखरखाव के लिए।
अंतर्वस्तु
एक लाभदायक प्रलेखन में अनिवार्य रूप से निम्नलिखित सामग्री शामिल होनी चाहिए -
High–level system architecture - प्रक्रिया आरेख और मॉड्यूल आरेख
Key abstractions and mechanisms - कक्षा आरेख और वस्तु आरेख।
Scenarios that illustrate the behavior of the main aspects - व्यवहारिक आरेख
विशेषताएं
एक अच्छे दस्तावेज की विशेषताएं हैं -
संक्षिप्त और उसी समय, असंदिग्ध, सुसंगत और पूर्ण
सिस्टम की आवश्यकता के विनिर्देशों के लिए उपयुक्त
Well-structured
वर्णनात्मक के बजाय आरेख