सॉफ्टवेयर डिजाइन रणनीतियाँ
सॉफ्टवेयर डिजाइन सॉफ्टवेयर कार्यान्वयन में सॉफ्टवेयर आवश्यकताओं की अवधारणा के लिए एक प्रक्रिया है। सॉफ्टवेयर डिजाइन उपयोगकर्ता की आवश्यकताओं को चुनौतियों के रूप में लेता है और इष्टतम समाधान खोजने की कोशिश करता है। जबकि सॉफ्टवेयर की परिकल्पना की जा रही है, एक योजना को हल करने के लिए सबसे अच्छा संभव डिजाइन खोजने के लिए किया गया है।
सॉफ्टवेयर डिजाइन के कई प्रकार हैं। आइए हम उनका संक्षेप में अध्ययन करें:
संरचित डिजाइन
संरचित डिजाइन समाधान के कई सुव्यवस्थित तत्वों में समस्या की अवधारणा है। यह मूल रूप से समाधान डिजाइन के साथ संबंध है। संरचित डिजाइन का लाभ यह है, यह बेहतर समझ देता है कि समस्या को कैसे हल किया जा रहा है। संरचित डिजाइन भी डिजाइनर के लिए समस्या को और अधिक सटीक रूप से ध्यान केंद्रित करने के लिए सरल बनाता है।
संरचित डिजाइन ज्यादातर 'फूट डालो और जीतो' की रणनीति पर आधारित है जहां एक समस्या को कई छोटी समस्याओं में तोड़ दिया जाता है और प्रत्येक छोटी समस्या को व्यक्तिगत रूप से हल किया जाता है जब तक कि पूरी समस्या हल न हो जाए।
समाधान मॉड्यूल के माध्यम से समस्या के छोटे टुकड़े हल किए जाते हैं। संरचित डिजाइन जोर देते हैं कि सटीक समाधान प्राप्त करने के लिए इन मॉड्यूल को अच्छी तरह से व्यवस्थित किया जाए।
ये मॉड्यूल पदानुक्रम में व्यवस्थित होते हैं। वे एक-दूसरे से संवाद करते हैं। एक अच्छी संरचित डिजाइन हमेशा कई मॉड्यूलों के बीच संचार के कुछ नियमों का पालन करती है, जैसे -
Cohesion - सभी कार्यात्मक रूप से संबंधित तत्वों का समूह।
Coupling - विभिन्न मॉड्यूल के बीच संचार।
एक अच्छी संरचित डिजाइन में उच्च सामंजस्य और कम युग्मन की व्यवस्था होती है।
उन्मुख डिजाइन
फ़ंक्शन-ओरिएंटेड डिज़ाइन में, सिस्टम कई छोटे उप-प्रणालियों से युक्त होता है जिन्हें फ़ंक्शन के रूप में जाना जाता है। ये कार्य प्रणाली में महत्वपूर्ण कार्य करने में सक्षम हैं। सिस्टम को सभी कार्यों के शीर्ष दृश्य के रूप में माना जाता है।
फंक्शन ओरिएंटेड डिज़ाइन संरचित डिज़ाइन के कुछ गुणों को विरासत में देता है जहाँ कार्यप्रणाली का विभाजन और जीत होती है।
यह डिज़ाइन तंत्र पूरे सिस्टम को छोटे कार्यों में विभाजित करता है, जो जानकारी और उनके संचालन को छिपाकर अमूर्तता का साधन प्रदान करता है .. ये कार्यात्मक मॉड्यूल वैश्विक रूप से उपलब्ध जानकारी के गुजरने और उपयोग करने के माध्यम से आपस में जानकारी साझा कर सकते हैं।
कार्यों की एक और विशेषता यह है कि जब कोई प्रोग्राम किसी फ़ंक्शन को कॉल करता है, तो फ़ंक्शन प्रोग्राम की स्थिति को बदल देता है, जो कभी-कभी अन्य मॉड्यूल द्वारा स्वीकार्य नहीं होता है। फंक्शन ओरिएंटेड डिज़ाइन अच्छी तरह से काम करता है जहाँ सिस्टम स्थिति मायने नहीं रखती है और प्रोग्राम / फंक्शन इनपुट पर काम करते हैं बजाय स्टेट पर।
डिज़ाइन प्रक्रिया
- पूरे सिस्टम को देखा जाता है कि डेटा प्रवाह आरेख के माध्यम से सिस्टम में डेटा कैसे प्रवाहित होता है।
- DFD दर्शाती है कि कैसे कार्य पूरे सिस्टम की डेटा और स्थिति को बदलता है।
- पूरी प्रणाली तार्किक रूप से सिस्टम में उनके संचालन के आधार पर कार्यों के रूप में जानी जाने वाली छोटी इकाइयों में टूट जाती है।
- प्रत्येक फ़ंक्शन को तब बड़े पैमाने पर वर्णित किया जाता है।
ऑब्जेक्ट ओरिएंटेड डिज़ाइन
ऑब्जेक्ट ओरिएंटेड डिज़ाइन सॉफ्टवेयर सिस्टम में शामिल फ़ंक्शंस के बजाय संस्थाओं और उनकी विशेषताओं के आसपास काम करता है। यह डिजाइन रणनीतियों संस्थाओं और इसकी विशेषताओं पर केंद्रित है। सॉफ्टवेयर सॉल्यूशन की पूरी अवधारणा संलग्न संस्थाओं के चारों ओर घूमती है।
आइये देखते हैं ऑब्जेक्ट ओरिएंटेड डिज़ाइन की महत्वपूर्ण अवधारणाएँ:
- Objects - समाधान डिजाइन में शामिल सभी संस्थाओं को वस्तुओं के रूप में जाना जाता है। उदाहरण के लिए, व्यक्ति, बैंक, कंपनी और ग्राहकों को वस्तुओं के रूप में माना जाता है। प्रत्येक इकाई में कुछ विशेषताएं जुड़ी होती हैं और विशेषताओं पर प्रदर्शन करने के लिए कुछ तरीके होते हैं।
Classes - एक वर्ग एक वस्तु का सामान्यीकृत वर्णन है। एक वस्तु एक वर्ग का एक उदाहरण है। क्लास सभी विशेषताओं को परिभाषित करता है, जिसमें एक वस्तु हो सकती है और विधियाँ, जो वस्तु की कार्यक्षमता को परिभाषित करती हैं।
समाधान डिजाइन में, विशेषताओं को चर के रूप में संग्रहीत किया जाता है और कार्यविधियों को तरीकों या प्रक्रियाओं के माध्यम से परिभाषित किया जाता है।
- Encapsulation - OOD में, विशेषताओं (डेटा चर) और विधियों (डेटा पर संचालन) को एक साथ बंडल किया जाता है जिसे एनकैप्सुलेशन कहा जाता है। एनकैप्सुलेशन न केवल एक वस्तु की महत्वपूर्ण जानकारी को एक साथ बंडल करता है, बल्कि बाहरी दुनिया से डेटा और विधियों की पहुंच को भी प्रतिबंधित करता है। इसे सूचना छिपाना कहते हैं।
- Inheritance - OOD समान वर्गों को श्रेणीबद्ध तरीके से स्टैक करने की अनुमति देता है जहां निम्न या उप-वर्ग अपने तत्काल सुपर क्लास से अनुमत चर और विधियों का आयात, कार्यान्वयन और पुन: उपयोग कर सकते हैं। OOD की इस संपत्ति को विरासत के रूप में जाना जाता है। इससे विशिष्ट वर्ग को परिभाषित करना और विशिष्ट लोगों से सामान्यीकृत कक्षाएं बनाना आसान हो जाता है।
- Polymorphism - OOD भाषाएँ एक ऐसा तंत्र प्रदान करती हैं जहाँ समान कार्य करने वाली विधियाँ लेकिन तर्कों में भिन्न होती हैं, उन्हें समान नाम दिया जा सकता है। इसे बहुरूपता कहा जाता है, जो एकल इंटरफ़ेस को विभिन्न प्रकारों के लिए कार्य करने की अनुमति देता है। फ़ंक्शन को कैसे लागू किया जाता है, इसके आधार पर, कोड का संबंधित भाग निष्पादित हो जाता है।
डिज़ाइन प्रक्रिया
सॉफ़्टवेयर डिज़ाइन प्रक्रिया को अच्छी तरह से परिभाषित चरणों की श्रृंखला के रूप में माना जा सकता है। हालाँकि यह डिज़ाइन एप्रोच (फ़ंक्शन ओरिएंटेड या ऑब्जेक्ट ओरिएंटेड) के अनुसार भिन्न होता है, फिर भी इसमें निम्नलिखित चरण शामिल हो सकते हैं:
- एक समाधान डिज़ाइन आवश्यकता या पिछले उपयोग किए गए सिस्टम और / या सिस्टम अनुक्रम आरेख से बनाया गया है।
- विशेषता विशेषताओं में समानता की ओर से वस्तुओं की पहचान की जाती है और उन्हें कक्षाओं में वर्गीकृत किया जाता है।
- वर्ग पदानुक्रम और उनके बीच संबंध परिभाषित किया गया है।
- एप्लिकेशन फ्रेमवर्क परिभाषित किया गया है।
सॉफ्टवेयर डिजाइन दृष्टिकोण
सॉफ्टवेयर डिजाइनिंग के लिए यहां दो सामान्य दृष्टिकोण हैं:
शीर्ष नीचे डिजाइन
हम जानते हैं कि एक प्रणाली एक से अधिक उप-प्रणालियों से बनी होती है और इसमें कई घटक होते हैं। इसके अलावा, इन उप-प्रणालियों और घटकों में उप-प्रणाली और घटकों के सेट पर हो सकता है और सिस्टम में पदानुक्रमित संरचना बनाता है।
टॉप-डाउन डिज़ाइन पूरे सॉफ्टवेयर सिस्टम को एक इकाई के रूप में लेता है और फिर कुछ विशेषताओं के आधार पर एक से अधिक उप-प्रणाली या घटक को प्राप्त करने के लिए इसे विघटित करता है। प्रत्येक उप-प्रणाली या घटक को तब एक प्रणाली के रूप में माना जाता है और आगे विघटित किया जाता है। यह प्रक्रिया तब तक चलती रहती है जब तक कि टॉप-डाउन पदानुक्रम में सिस्टम का निम्नतम स्तर हासिल नहीं हो जाता।
टॉप-डाउन डिज़ाइन सिस्टम के एक सामान्यीकृत मॉडल से शुरू होता है और इसके अधिक विशिष्ट भाग को परिभाषित करता रहता है। जब सभी घटकों की रचना की जाती है तो पूरी प्रणाली अस्तित्व में आती है।
टॉप-डाउन डिज़ाइन अधिक उपयुक्त है जब सॉफ्टवेयर समाधान को खरोंच से डिज़ाइन करने की आवश्यकता होती है और विशिष्ट विवरण अज्ञात होते हैं।
बॉटम-अप डिज़ाइन
नीचे का डिज़ाइन मॉडल सबसे विशिष्ट और बुनियादी घटकों के साथ शुरू होता है। यह बुनियादी या निचले स्तर के घटकों का उपयोग करके उच्च स्तर के घटकों की रचना के साथ आगे बढ़ता है। यह तब तक उच्च स्तर के घटक बनाता रहता है जब तक कि वांछित प्रणाली एक एकल घटक के रूप में विकसित नहीं होती है। प्रत्येक उच्च स्तर के साथ, अमूर्तता की मात्रा बढ़ जाती है।
बॉटम-अप रणनीति तब अधिक उपयुक्त होती है जब किसी सिस्टम को कुछ मौजूदा सिस्टम से बनाने की जरूरत होती है, जहां नए सिस्टम में बेसिक प्राइमिटिव्स का इस्तेमाल किया जा सकता है।
दोनों, टॉप-डाउन और बॉटम-अप दृष्टिकोण व्यक्तिगत रूप से व्यावहारिक नहीं हैं। इसके बजाय, दोनों का एक अच्छा संयोजन उपयोग किया जाता है।