ऑब्जेक्ट ओरिएंटेड दृष्टिकोण

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

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

OO मॉडल निम्नलिखित तरीकों से फायदेमंद है -

  • यह कम लागत पर सिस्टम में बदलाव की सुविधा देता है।

  • यह घटकों के पुन: उपयोग को बढ़ावा देता है।

  • यह बड़े सिस्टम को कॉन्फ़िगर करने के लिए घटकों को एकीकृत करने की समस्या को सरल करता है।

  • यह वितरित प्रणालियों के डिजाइन को सरल करता है।

ऑब्जेक्ट ओरिएंटेड सिस्टम के तत्व

आइए हम OO सिस्टम की विशेषताओं के माध्यम से जाने -

  • Objects- एक वस्तु ऐसी चीज है जो समस्या डोमेन में मौजूद है और इसे डेटा (विशेषता) या व्यवहार द्वारा पहचाना जा सकता है। सभी मूर्त इकाइयाँ (छात्र, रोगी) और कुछ अमूर्त निकाय (बैंक खाता) वस्तु के रूप में तैयार किए जाते हैं।

  • Attributes - वे वस्तु के बारे में जानकारी का वर्णन करते हैं।

  • Behavior- यह निर्दिष्ट करता है कि ऑब्जेक्ट क्या कर सकता है। यह वस्तुओं पर किए गए ऑपरेशन को परिभाषित करता है।

  • Class- एक वर्ग डेटा और उसके व्यवहार को समझाया जाता है। समान अर्थ और उद्देश्य वाली वस्तुओं को एक साथ वर्ग के रूप में वर्गीकृत किया गया है।

  • Methods- विधियाँ एक वर्ग के व्यवहार को निर्धारित करती हैं। वे एक क्रिया से अधिक कुछ नहीं हैं जो एक वस्तु प्रदर्शन कर सकती है।

  • Message- एक संदेश एक वस्तु या दूसरी वस्तु से दूसरे पर होने वाली क्रिया या प्रक्रिया है। वे तरीकों को ट्रिगर करने के लिए वस्तुओं को भेजी जाने वाली जानकारी हैं। अनिवार्य रूप से, एक संदेश एक वस्तु या दूसरी वस्तु से दूसरी प्रक्रिया या प्रक्रिया है।

ऑब्जेक्ट-ओरिएंटेड सिस्टम की विशेषताएं

ऑब्जेक्ट-ओरिएंटेड सिस्टम कई बेहतरीन विशेषताओं के साथ आता है, जिनकी चर्चा नीचे की गई है।

कैप्सूलीकरण

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

मतिहीनता

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

रिश्तों

सिस्टम में सभी वर्ग एक-दूसरे से संबंधित हैं। वस्तुओं के अलगाव में मौजूद नहीं है, वे अन्य वस्तुओं के साथ संबंध में मौजूद हैं।

वस्तु संबंध तीन प्रकार के होते हैं -

  • Aggregation - यह एक पूरे और उसके भागों के बीच संबंध को इंगित करता है।

  • Association - इसमें दो वर्ग किसी न किसी तरह से संबंधित या जुड़े होते हैं जैसे एक वर्ग दूसरे के साथ कार्य करने के लिए काम करता है या अन्य वर्ग पर एक वर्ग कार्य करता है।

  • Generalization- चाइल्ड क्लास पैरेंट क्लास पर आधारित है। यह इंगित करता है कि दो वर्ग समान हैं लेकिन कुछ अंतर हैं।

विरासत

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

बहुरूपता और गतिशील बंधन

बहुरूपता कई विभिन्न रूपों को लेने की क्षमता है। यह ऑब्जेक्ट्स और ऑपरेशंस दोनों पर लागू होता है। एक पॉलीमॉर्फिक ऑब्जेक्ट वह है जो सही प्रकार एक सुपर या पैरेंट क्लास के भीतर छिपा होता है।

बहुरूपी ऑपरेशन में, वस्तुओं के विभिन्न वर्गों द्वारा ऑपरेशन को अलग तरीके से किया जा सकता है। यह हमें केवल उनके सामान्य गुणों को जानकर विभिन्न वर्गों की वस्तुओं में हेरफेर करने की अनुमति देता है।

संरचित दृष्टिकोण बनाम। ऑब्जेक्ट ओरिएंटेड दृष्टिकोण

निम्न तालिका बताती है कि ऑब्जेक्ट-ओरिएंटेड दृष्टिकोण पारंपरिक संरचित दृष्टिकोण से कैसे भिन्न होता है -

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

एकीकृत मॉडलिंग भाषा (UML)

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

इसे ऑब्जेक्ट मैनेजमेंट ग्रुप द्वारा निर्मित और वितरित विनिर्देशों के रूप में परिभाषित किया गया है। यूएमएल एक्स्टेंसिबल और स्केलेबल है।

यूएमएल का उद्देश्य वस्तु-उन्मुख शब्दों और आरेख तकनीकों की एक आम शब्दावली प्रदान करना है जो कार्यान्वयन के माध्यम से विश्लेषण से किसी भी सिस्टम विकास परियोजना को मॉडल करने के लिए पर्याप्त समृद्ध है।

UML किससे बना है -

  • Diagrams - यह प्रक्रिया, प्रणाली या इसके कुछ भाग का सचित्र प्रतिनिधित्व है।

  • Notations - इसमें ऐसे तत्व शामिल होते हैं जो एक आरेख में एक साथ काम करते हैं जैसे कनेक्टर, प्रतीक, नोट्स, आदि।

क्लास के लिए यूएमएल नोटेशन का उदाहरण

उदाहरण आरेख-यूएमएल संकेतन

संचालन वस्तुओं पर प्रदर्शन किया

निम्नलिखित ऑपरेशन वस्तुओं पर किए जाते हैं -

  • Constructor/Destructor- एक वर्ग के नए उदाहरण बनाना और एक वर्ग के मौजूदा उदाहरणों को हटाना। उदाहरण के लिए, एक नया कर्मचारी जोड़ना।

  • Query- मूल्य बदले बिना राज्य में प्रवेश करने का कोई दुष्प्रभाव नहीं है। उदाहरण के लिए, किसी विशेष कर्मचारी का पता खोजना।

  • Update - एक या अधिक विशेषताओं का परिवर्तन और वस्तु की स्थिति को प्रभावित करना। उदाहरण के लिए, किसी कर्मचारी का पता बदलना।

यूएमएल के उपयोग

यूएमएल निम्नलिखित उद्देश्यों के लिए काफी उपयोगी है -

  • व्यापार प्रक्रिया मॉडलिंग
  • सिस्टम आर्किटेक्चर का वर्णन करना
  • एप्लिकेशन संरचना दिखा रहा है
  • सिस्टम के व्यवहार को पकड़ना
  • डेटा संरचना मॉडलिंग
  • प्रणाली के विस्तृत विनिर्देशों का निर्माण
  • विचारों को स्केच करना
  • प्रोग्राम कोड जनरेट करना

स्थैतिक मॉडल

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

  • उनका उपयोग वर्ग के नाम, गुण, तरीके, हस्ताक्षर और पैकेज को परिभाषित करने के लिए किया जाता है।

  • यूएमएल आरेख जो स्थिर मॉडल का प्रतिनिधित्व करते हैं, उनमें वर्ग आरेख, ऑब्जेक्ट आरेख और उपयोग केस आरेख शामिल हैं।

गतिशील मॉडल

डायनामिक मॉडल एक सिस्टम की व्यवहारिक विशेषताओं को दर्शाता है, अर्थात, बाहरी घटनाओं की प्रतिक्रिया में सिस्टम कैसे व्यवहार करता है।

  • डायनामिक मॉडल आवश्यक वस्तु की पहचान करते हैं और वे कैसे तरीकों और संदेशों के माध्यम से मिलकर काम करते हैं।

  • उनका उपयोग प्रणाली के तर्क और व्यवहार को डिजाइन करने के लिए किया जाता है।

  • यूएमएल आरेख गतिशील मॉडल का प्रतिनिधित्व करते हैं जिसमें अनुक्रम आरेख, संचार आरेख, राज्य आरेख, गतिविधि आरेख शामिल हैं।

ऑब्जेक्ट ओरिएंटेड सिस्टम डेवलपमेंट लाइफ साइकिल

इसमें तीन स्थूल प्रक्रियाएँ शामिल हैं -

  • ऑब्जेक्ट ओरिएंटेड एनालिसिस (OOA)
  • ऑब्जेक्ट ओरिएंटेड डिज़ाइन (OOD)
  • वस्तु उन्मुख कार्यान्वयन (OOI)

ऑब्जेक्ट ओरिएंटेड सिस्टम डेवलपमेंट एक्टिविटीज़

ऑब्जेक्ट-ओरिएंटेड सिस्टम डेवलपमेंट में निम्न चरण शामिल हैं -

  • वस्तु-उन्मुख विश्लेषण
  • वस्तु उन्मुख डिजाइन
  • Prototyping
  • Implementation
  • वृद्धिशील परीक्षण

ऑब्जेक्ट-ओरिएंटेड विश्लेषण

यह चरण सिस्टम की आवश्यकताओं को निर्धारित करने और सिस्टम की आवश्यकताओं को समझने के साथ निर्माण करता है use-case model। उपयोगकर्ता और कंप्यूटर सिस्टम के बीच बातचीत का वर्णन करने के लिए एक उपयोग-मामला एक परिदृश्य है। यह मॉडल उपयोगकर्ता की जरूरतों या सिस्टम के उपयोगकर्ता दृश्य का प्रतिनिधित्व करता है।

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

ऑब्जेक्ट-ओरिएंटेड डिज़ाइन

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

प्रोटोटाइप

प्रोटोटाइप पूरी तरह से समझने में सक्षम है कि सिस्टम की कुछ विशेषताओं को लागू करना कितना आसान या कठिन होगा।

यह उपयोगकर्ताओं को डिजाइन की उपयोगिता और उपयोगिता पर टिप्पणी करने का मौका भी दे सकता है। यह आगे एक उपयोग-केस को परिभाषित कर सकता है और उपयोग-केस मॉडलिंग को बहुत आसान बना सकता है।

कार्यान्वयन

यह या तो घटक-आधारित विकास (CBD) या रैपिड एप्लिकेशन डेवलपमेंट (RAD) का उपयोग करता है।

घटक आधारित विकास (CBD)

सीओएसडी विभिन्न प्रकार की तकनीकों जैसे CASE टूल का उपयोग करके सॉफ्टवेयर विकास प्रक्रिया के लिए एक औद्योगिक दृष्टिकोण है। पूर्व-निर्मित, पूर्व-परीक्षण किए गए, पुन: प्रयोज्य सॉफ़्टवेयर घटकों के असेंबली के कस्टम विकास से अनुप्रयोग विकास चलता है जो एक दूसरे के साथ काम करते हैं। एक CBD डेवलपर घटकों को इकट्ठा करके एक पूर्ण सॉफ्टवेयर सिस्टम का निर्माण कर सकता है।

रैपिड एप्लीकेशन डेवलपमेंट (RAD)

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

इसका कार्य अनुप्रयोग को शीघ्रता से और वृद्धिशील रूप से उपयोगकर्ता की आवश्यकताओं के डिजाइन को लागू करना है जैसे विज़ुअल बेसिक, पावर बिल्डर, आदि।

वृद्धिशील परीक्षण

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