छोड़कर सामग्री पर जाएँ
Read this post in: de_DEen_USes_ESfr_FRhi_INid_IDjapl_PLpt_PTru_RUvizh_CNzh_TW
Home » UML » उपयोग केस से MVC फ्रेमवर्क तक: ऑब्जेक्ट-ओरिएंटेड सिस्टम विकास का मार्गदर्शिका

उपयोग केस से MVC फ्रेमवर्क तक: ऑब्जेक्ट-ओरिएंटेड सिस्टम विकास का मार्गदर्शिका

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

MVC framework

चरण 1: उपयोग केस की पहचान करें

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

चरण 2: क्लास की पहचान करें

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

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

चरण 3: संबंधों की पहचान करें

क्लास की पहचान करने के बाद, आपको यह निर्धारित करना होगा कि वे एक दूसरे से कैसे संबंधित हैं। क्लास के बीच के संबंधों को संबंध, एग्रीगेशन या संघटन के उपयोग से दर्शाया जा सकता है।

संबंध दो क्लास के बीच के संबंध का प्रतिनिधित्व करता है, जहां एक क्लास दूसरी क्लास की सेवाओं का उपयोग करता है। एग्रीगेशन दो क्लास के बीच के संबंध का प्रतिनिधित्व करता है, जहां एक क्लास दूसरी क्लास को एक हिस्से के रूप में समावेश करता है, लेकिन हिस्सा पूर्ण के बिना स्वतंत्र रूप से अस्तित्व में हो सकता है। संघटन दो क्लास के बीच के संबंध का प्रतिनिधित्व करता है, जहां एक क्लास दूसरी क्लास को एक हिस्से के रूप में समावेश करता है, और हिस्सा पूर्ण के बिना स्वतंत्र रूप से अस्तित्व में नहीं हो सकता है।

चरण 4: क्लास आरेख विकसित करें

पहचाने गए क्लास और संबंधों के उपयोग से, आप एक क्लास आरेख बना सकते हैं। एक क्लास आरेख क्लास और उनके संबंधों का दृश्य प्रतिनिधित्व है। यह प्रत्येक क्लास के गुण और विधियों और क्लास के बीच के संबंधों को दर्शाता है।

क्लास आरेख में, प्रत्येक क्लास को एक बॉक्स के रूप में दर्शाया जाता है, जिसके ऊपर क्लास का नाम होता है। क्लास के गुण बॉक्स के बीच में सूचीबद्ध होते हैं, और विधियाँ बॉक्स के नीचे सूचीबद्ध होती हैं। क्लास के बीच के संबंध रेखाओं के उपयोग से दर्शाए जाते हैं, जहां विभिन्न रेखा प्रकार विभिन्न प्रकार के संबंधों का प्रतिनिधित्व करते हैं।

चरण 5: क्लास आरेख को MVC विस्तृत क्लास आरेख में सुधारें

क्लास आरेख बनाने के बाद, आप इसे MVC विस्तृत क्लास आरेख में सुधार सकते हैं। दमॉडल-व्यू-नियंत्रक (MVC) पैटर्न एक सॉफ्टवेयर डिजाइन पैटर्न है जो एक एप्लिकेशन को तीन एक दूसरे से जुड़े घटकों में विभाजित करता है: मॉडल, व्यू और नियंत्रक।

मॉडल एप्लिकेशन के डेटा और व्यावसायिक तर्क का प्रतिनिधित्व करता है। व्यू एप्लिकेशन के उपयोगकर्ता इंटरफेस का प्रतिनिधित्व करता है। नियंत्रक मॉडल और व्यू के बीच संचार का प्रबंधन करता है।

क्लास आरेख को MVC विस्तृत क्लास आरेख में सुधारने के लिए, आपको यह पहचानना होगा कि कौन सी क्लास मॉडल, व्यू और नियंत्रक का प्रतिनिधित्व करती हैं। मॉडल क्लास में एप्लिकेशन के डेटा और व्यावसायिक तर्क शामिल होने चाहिए। व्यू क्लास में एप्लिकेशन के उपयोगकर्ता इंटरफेस शामिल होने चाहिए। नियंत्रक क्लास मॉडल और व्यू के बीच संचार का प्रबंधन करने चाहिए।

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

उदाहरण: कार रेंटल सिस्टम

समस्या विवरण: एक कार रेंटल कंपनी ऑनलाइन कार रेंट करने की अनुमति देने वाला एक सॉफ्टवेयर सिस्टम विकसित करना चाहती है। ग्राहकों को उपलब्ध कारों को ब्राउज़ करने, कार चुनने और बुकिंग करने की अनुमति होनी चाहिए। सिस्टम को कारों की उपलब्धता और ग्राहकों द्वारा की गई बुकिंग का ट्रैक रखना चाहिए।

चरण 1: उपयोग केस की पहचान करें

  • उपलब्ध कारों को ब्राउज़ करें
  • किराए पर लेने के लिए एक कार चुनें
  • बुकिंग करें

Car Rental Use Case Diagram

यह उपयोग केस आरेख चरण 1 में पहचाने गए तीन मुख्य उपयोग केस को दर्शाता है: उपलब्ध कारों को ब्राउज़ करें, किराए पर लेने के लिए एक कार चुनें, और बुकिंग करें। ग्राहक अभिनेता कार रेंटल सिस्टम के साथ इन क्रियाकलापों को करने के लिए बातचीत करता है।

चरण 2: क्लास की पहचान करें

  • ग्राहक
  • कार
  • आरक्षण

चरण 3: संबंधों की पहचान करें

  • एक ग्राहक बहुत सारे आरक्षण कर सकता है, लेकिन प्रत्येक आरक्षण केवल एक ग्राहक द्वारा किया जाता है। यह एक से बहुत के संबंध है, जिसे ग्राहक और आरक्षण वर्गों के बीच संबंध द्वारा दर्शाया गया है।
  • एक कार कई ग्राहकों द्वारा किराए पर ली जा सकती है, लेकिन प्रत्येक किराए के लिए केवल एक कार होती है। यह भी एक से बहुत के संबंध है, जिसे कार और आरक्षण वर्गों के बीच संबंध द्वारा दर्शाया गया है।

चरण 4: क्लास डायग्राम विकसित करें

Car Rental Simple Class Diagram

यह क्लास डायग्राम चरण 2 में पहचाने गए तीन मुख्य वर्गों को दर्शाता है: ग्राहक, कार और आरक्षण। यह चरण 3 में पहचाने गए संबंधों को भी दर्शाता है: ग्राहक और आरक्षण के बीच एक से बहुत का संबंध, और कार और आरक्षण के बीच एक से बहुत का संबंध। प्रत्येक वर्ग में विश्लेषण चरण के दौरान पहचाने गए गुण और विधियाँ भी शामिल हैं।

चरण 5: क्लास डायग्राम को MVC विस्तृत क्लास डायग्राम में सुधारें

  • मॉडल: कार, ग्राहक, आरक्षण
  • दृश्य: उपयोगकर्ता इंटरफेस (UI)
  • नियंत्रक: कार रेंटल कंट्रोलर

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

Refined Car Rental Class Diagram (MVC)

ध्यान दें कि:

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

वस्तु मॉडलिंग परिणाम के आधार पर ERD बनाएं

यह ERD समस्या विवरण में पहचाने गए तीन मुख्य एंटिटी को दर्शाता है: ग्राहक, कार और बुकिंग। इसमें इन एंटिटी के बीच संबंध भी दिखाए गए हैं: ग्राहक और बुकिंग के बीच एक से बहुत के संबंध, कार और बुकिंग के बीच एक से बहुत के संबंध, और ग्राहक और कार के बीच कोई सीधा संबंध नहीं है। प्रत्येक एंटिटी में विश्लेषण चरण के दौरान पहचाने गए गुण होते हैं।

Car Rental ERD

ERD केवल सिस्टम के डेटा पर्सिस्टेंस लेयर के मॉडलिंग के लिए जिम्मेदार है, जबकि क्लास डायग्राम मॉडल, व्यू और कंट्रोलर लेयर सहित पूरे सिस्टम के मॉडलिंग के लिए जिम्मेदार है।

दूसरे शब्दों में, ERD डेटाबेस स्कीमा और टेबल/एंटिटी के बीच संबंधों का प्रतिनिधित्व करता है, जबकि क्लास डायग्राम पूरे सिस्टम के निर्माण में शामिल क्लासेज और उनके संबंध, गुण और विधियों का प्रतिनिधित्व करता है।

 

क्लास डायग्राम को बेहतर बनाने के लिए गायब वस्तुओं की पहचान कैसे करें

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

Car Rental MVC Sequence Diagram

उपयोग केस स्थिति से पाए गए गायब वस्तुओं के साथ MVC क्लास डायग्राम को बेहतर बनाएं

जब हम MVC अनुक्रम डायग्राम प्रक्रिया के माध्यम से गुजर रहे होते हैं, तो हम अतिरिक्त वस्तुओं की खोज कर सकते हैं जिन्हें MVC क्लास डायग्राम में शामिल करने की आवश्यकता है ताकि सिस्टम के व्यवहार का पूरा प्रतिनिधित्व किया जा सके। MVC क्लास डायग्राम को बेहतर बनाने के लिए हम निम्नलिखित चरणों का पालन कर सकते हैं:

  1. गायब वस्तुओं की पहचान करें: MVC अनुक्रम डायग्राम विकसित करते समय, हम कुछ गायब वस्तुओं की पहचान कर सकते हैं जो मौजूदा वस्तुओं के बीच अंतरक्रिया पूरी करने के लिए आवश्यक हैं। इन गायब वस्तुओं में नए एंटिटी, सेवाएं या कंट्रोलर शामिल हो सकते हैं जिन्हें प्रारंभिक MVC क्लास डायग्राम में शुरू में ध्यान में नहीं लिया गया था।
  2. गायब वस्तुओं को MVC क्लास डायग्राम में जोड़ें: जब हम गायब वस्तुओं की पहचान कर लेते हैं, तो हम उन्हें मौजूदा MVC क्लास डायग्राम में जोड़ सकते हैं। हम मौजूदा वस्तुओं और नई वस्तुओं के बीच संबंधों को आवश्यकता के अनुसार संशोधित कर सकते हैं।
  3. संबंधों की समीक्षा और बेहतर बनाना: MVC क्लास डायग्राम में गायब वस्तुओं को जोड़ने के बाद, हमें वस्तुओं के बीच संबंधों की समीक्षा करनी चाहिए और यह सुनिश्चित करना चाहिए कि वे सिस्टम के व्यवहार का सही प्रतिनिधित्व करते हैं। हमें नई वस्तुओं को ध्यान में रखते हुए वस्तुओं के बीच संबंधों को संशोधित करने की आवश्यकता हो सकती है और यह सुनिश्चित करना चाहिए कि डायग्राम आसानी से समझ में आए।
  4. आवश्यकता के अनुसार दोहराएं: यदि अनुक्रम डायग्राम प्रक्रिया के दौरान हम अतिरिक्त गायब वस्तुओं की खोज करते हैं, तो हम ऊपर दिए गए चरणों को दोहरा सकते हैं ताकि MVC क्लास डायग्राम को तब तक बेहतर बनाया जा सके जब तक यह सिस्टम के व्यवहार का सही प्रतिनिधित्व नहीं करता।

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

Car Rental Class Diagram Refined (Miss objs discovered)

निष्कर्ष

वर्गों की पहचान करने और क्लास डायग्राम विकसित करने की प्रक्रिया सॉफ्टवेयर सिस्टम के डिजाइन और विकास के लिए एक महत्वपूर्ण चरण है। यह सुनिश्चित करने में मदद करता है कि सिस्टम अच्छी तरह से संगठित हो, आसानी से बनाए रखा जा सके और उपयोगकर्ताओं की आवश्यकताओं को पूरा करे।

इस लेख में बताए गए चरणों का पालन करके – उपयोग केस विश्लेषण से शुरू करके और MVC क्लास डायग्राम के निर्माण पर समाप्त करके – डेवलपर्स यह सुनिश्चित कर सकते हैं कि उनके सॉफ्टवेयर सिस्टम सही तरीके से डिजाइन किए गए हैं, जिसमें प्रत्येक सिस्टम घटक के लिए स्पष्ट रूप से परिभाषित क्लासेज, संबंध और जिम्मेदारियां हों।

समग्र रूप से, वर्गों की पहचान करने और क्लास डायग्राम बनाने की प्रक्रिया चुनौतिपूर्ण हो सकती है, लेकिन यह उपयोगकर्ताओं और हितधारकों की आवश्यकताओं को पूरा करने वाले उच्च गुणवत्ता वाले सॉफ्टवेयर सिस्टम बनाने के लिए एक आवश्यक चरण है।

प्रातिक्रिया दे