OOAD - त्वरित गाइड

एक संक्षिप्त इतिहास

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

  • पहली वस्तु-उन्मुख भाषा सिमूला (वास्तविक प्रणालियों का अनुकरण) थी जिसे 1960 में नॉर्वेजियन कम्प्यूटिंग सेंटर के शोधकर्ताओं द्वारा विकसित किया गया था।

  • 1970 में, ज़ेरॉक्स PARK में एलन के और उनके शोध समूह ने डायनाबूक नाम का एक व्यक्तिगत कंप्यूटर बनाया और डायनबूक की प्रोग्रामिंग के लिए पहला शुद्ध ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग लैंग्वेज (OOPL) - स्मॉलटाक, बनाया।

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

  • 1990 के दशक में, कोएड ने व्यवहार-संबंधी विचारों को ऑब्जेक्ट-ओरिएंटेड विधियों में शामिल किया।

अन्य महत्वपूर्ण नवाचारों में जेम्स रंबॉ और ऑब्जेक्ट ओरिएंटेड सॉफ्टवेयर इंजीनियरिंग (ओओएसई) द्वारा आइवर जैकबसन द्वारा ऑब्जेक्ट मॉडलिंग तकनीक (ओएमटी) थे।

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

ऑब्जेक्ट-ओरिएंटेड एनालिसिस (OOA) एक सॉफ्टवेयर सिस्टम के ऑब्जेक्ट मॉडल के संदर्भ में सॉफ्टवेयर इंजीनियरिंग आवश्यकताओं की पहचान करने और सॉफ्टवेयर विनिर्देशों को विकसित करने की प्रक्रिया है, जिसमें ऑब्जेक्ट्स को इंटरैक्ट करना शामिल है।

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

ग्रैडी बूच ने ओओए को परिभाषित किया है, "ऑब्जेक्ट-ओरिएंटेड विश्लेषण विश्लेषण का एक तरीका है जो समस्या डोमेन की शब्दावली में पाए जाने वाले वर्गों और वस्तुओं के परिप्रेक्ष्य से आवश्यकताओं की जांच करता है"

ऑब्जेक्ट-ओरिएंटेड विश्लेषण (OOA) में प्राथमिक कार्य हैं -

  • वस्तुओं की पहचान
  • ऑब्जेक्ट मॉडल आरेख बनाकर वस्तुओं को व्यवस्थित करना
  • ऑब्जेक्ट या ऑब्जेक्ट विशेषताओं के आंतरिक को परिभाषित करना
  • वस्तुओं के व्यवहार को परिभाषित करना, अर्थात, वस्तु क्रियाएँ
  • यह बताते हुए कि ऑब्जेक्ट कैसे इंटरैक्ट करते हैं

OOA में उपयोग किए जाने वाले सामान्य मॉडल मामलों और ऑब्जेक्ट मॉडल का उपयोग करते हैं।

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

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

कार्यान्वयन विवरण में आम तौर पर शामिल हैं -

  • वर्ग डेटा को पुनर्स्थापित करना (यदि आवश्यक हो),
  • विधियों का कार्यान्वयन, अर्थात, आंतरिक डेटा संरचना और एल्गोरिदम,
  • नियंत्रण का कार्यान्वयन, और
  • संघों का कार्यान्वयन।

ग्रैडी बूच ने ऑब्जेक्ट-ओरिएंटेड डिज़ाइन को " ऑब्जेक्ट-ओरिएंटेड डिकम्पोज़िशन की प्रक्रिया को शामिल करने की एक विधि और डिज़ाइन के तहत सिस्टम के स्थिर और गतिशील मॉडल दोनों को चित्रित करने के लिए एक अंकन के रूप में परिभाषित किया है "

ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग

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

ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग की महत्वपूर्ण विशेषताएं हैं -

  • कार्यक्रम डिजाइन में नीचे-अप दृष्टिकोण
  • कक्षाओं में वर्गीकृत वस्तुओं के आसपास आयोजित कार्यक्रम
  • ऑब्जेक्ट के डेटा पर काम करने के तरीकों के साथ डेटा पर ध्यान दें
  • कार्यों के माध्यम से वस्तुओं के बीच सहभागिता
  • मौजूदा कक्षाओं में सुविधाओं को जोड़कर नई कक्षाओं के निर्माण के माध्यम से डिजाइन की पुन: प्रयोज्य

ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग लैंग्वेज के कुछ उदाहरण हैं C ++, Java, Smalltalk, Delphi, C #, Perl, Python, Ruby, और PHP।

ग्रैडी बूच ने ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग को "कार्यान्वयन की एक विधि" के रूप में परिभाषित किया है जिसमें कार्यक्रमों को वस्तुओं के सहकारी संग्रह के रूप में आयोजित किया जाता है, जिनमें से प्रत्येक किसी वर्ग के एक उदाहरण का प्रतिनिधित्व करता है, और जिनकी कक्षाएं वंशानुगत रिश्तों के माध्यम से एकजुट कक्षाओं के पदानुक्रम के सभी सदस्य हैं ”

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

वस्तुओं और वर्गों

वस्तुओं और वर्गों की अवधारणाएं आंतरिक रूप से एक दूसरे से जुड़ी हुई हैं और वस्तु-उन्मुख प्रतिमान की नींव बनाती हैं।

वस्तु

एक वस्तु वस्तु-उन्मुख वातावरण में एक वास्तविक दुनिया तत्व है जिसमें एक भौतिक या एक वैचारिक अस्तित्व हो सकता है। प्रत्येक वस्तु है -

  • पहचान जो इसे सिस्टम में अन्य वस्तुओं से अलग करती है।

  • वह अवस्था जो किसी वस्तु के गुणधर्मों के साथ-साथ उन गुणों के मूल्यों को भी निर्धारित करती है जो वस्तु रखती है।

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

वस्तुओं को आवेदन की जरूरतों के अनुसार मॉडल किया जा सकता है। किसी वस्तु का भौतिक अस्तित्व हो सकता है, जैसे ग्राहक, कार, आदि; या एक अमूर्त वैचारिक अस्तित्व, जैसे एक परियोजना, एक प्रक्रिया, आदि।

कक्षा

एक वर्ग समान विशेषता वाले वस्तुओं के संग्रह का प्रतिनिधित्व करता है जो सामान्य व्यवहार प्रदर्शित करते हैं। यह उन वस्तुओं का खाका या विवरण देता है जिनसे इसे बनाया जा सकता है। किसी वर्ग के सदस्य के रूप में किसी वस्तु का निर्माण तात्कालिकता कहलाता है। इस प्रकार, वस्तु एक वर्ग का एक उदाहरण है।

एक वर्ग के घटक हैं -

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

  • संचालन का एक सेट जो कक्षा की वस्तुओं के व्यवहार को चित्रित करता है। संचालन को कार्यों या विधियों के रूप में भी संदर्भित किया जाता है।

Example

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

  • x- समन्वय, x- केंद्र के समन्वय को निरूपित करने के लिए
  • y- समन्वय, केंद्र के y- समन्वय को निरूपित करने के लिए
  • , वृत्त की त्रिज्या को दर्शाने के लिए

इसके कुछ कार्यों को निम्नानुसार परिभाषित किया जा सकता है -

  • FindArea (), क्षेत्र की गणना करने की विधि
  • परिधि की गणना करने की विधि, खोजक परिधि ()
  • स्केल (), त्रिज्या को बढ़ाने या घटाने की विधि

तात्कालिकता के दौरान, मूल्यों को कम से कम कुछ विशेषताओं के लिए सौंपा गया है। यदि हम एक ऑब्जेक्ट my_circle बनाते हैं, तो हम इसके राज्य का चित्रण करने के लिए x-निर्देशांक: 2, y-ord: 3, और a: 4 जैसे मान निर्दिष्ट कर सकते हैं। अब, यदि ऑपरेशन स्केल () 2 के स्केलिंग फैक्टर के साथ my_circle पर किया जाता है, तो वैरिएबल का मान 8 हो जाएगा। यह ऑपरेशन my_circle की स्थिति में बदलाव लाता है, अर्थात, ऑब्जेक्ट ने कुछ व्यवहार का प्रदर्शन किया है।

एनकैप्सुलेशन और डेटा छिपाना

कैप्सूलीकरण

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

डेटा छिपाना

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

Example

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

  • setValues ​​(), x- निर्देशांक, y- निर्देशांक, और a के लिए मान नियत करने की विधि
  • getValues ​​(), x- निर्देशांक, y- समन्वय, और a के मानों को पुनः प्राप्त करने की विधि

यहां ऑब्जेक्ट के निजी डेटा my_circle को किसी भी तरीके से सीधे एक्सेस नहीं किया जा सकता है जो कि क्लास सर्कल के भीतर एनकैप्सुलेटेड नहीं है। इसके बजाय इसे विधियों सेटवैल्यूज़ () और गेटवैल्यूज़ () के माध्यम से एक्सेस किया जाना चाहिए।

संदेश देना

किसी भी एप्लिकेशन को एक सामंजस्यपूर्ण तरीके से बातचीत करने वाली कई वस्तुओं की आवश्यकता होती है। सिस्टम में ऑब्जेक्ट संदेश पासिंग का उपयोग करके एक दूसरे के साथ संवाद कर सकते हैं। मान लीजिए कि एक सिस्टम में दो ऑब्जेक्ट हैं: obj1 और obj2। ऑब्जेक्ट obj1 ऑब्जेक्ट obj2 पर एक संदेश भेजता है, अगर obj1 obj2 अपने तरीकों में से एक को निष्पादित करना चाहता है।

संदेश पास करने की विशेषताएं हैं -

  • दो वस्तुओं के बीच गुजरने वाला संदेश आम तौर पर अप्रत्यक्ष होता है।
  • संदेश पासिंग ऑब्जेक्ट के बीच सभी इंटरैक्शन को सक्षम करता है।
  • मैसेज पास करने में अनिवार्य रूप से क्लास के तरीके शामिल हैं।
  • संदेश पारित करने में विभिन्न प्रक्रियाओं में वस्तुओं को शामिल किया जा सकता है।

विरासत

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

Example

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

वंशानुक्रम के प्रकार

  • Single Inheritance - एक उपवर्ग एक एकल सुपर-क्लास से निकलता है।

  • Multiple Inheritance - एक उपवर्ग एक से अधिक सुपर-वर्गों से प्राप्त होता है।

  • Multilevel Inheritance - एक उपवर्ग एक सुपर-क्लास से प्राप्त होता है जो बदले में दूसरे वर्ग और इसी तरह से प्राप्त होता है।

  • Hierarchical Inheritance - एक वर्ग में कई उप-वर्ग होते हैं, जिनमें से प्रत्येक में बाद के उप-वर्ग हो सकते हैं, जो कई स्तरों तक जारी रहते हैं, ताकि एक पेड़ की संरचना बनाई जा सके।

  • Hybrid Inheritance - एक जाली संरचना बनाने के लिए कई और बहुस्तरीय विरासत का संयोजन।

निम्नलिखित आकृति विभिन्न प्रकार की विरासत के उदाहरणों को दर्शाती है।

बहुरूपता

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

Example

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

सामान्यीकरण और विशेषज्ञता

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

सामान्यकरण

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

विशेषज्ञता

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

निम्नलिखित आंकड़ा सामान्यीकरण और विशेषज्ञता का एक उदाहरण दिखाता है।

लिंक और एसोसिएशन

संपर्क

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

संगति

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

एक एसोसिएशन की डिग्री

एक एसोसिएशन की डिग्री एक कनेक्शन में शामिल कक्षाओं की संख्या को दर्शाता है। डिग्री एकात्मक, बाइनरी या टर्नरी हो सकती है।

  • unary relationship एक ही वर्ग की वस्तुओं को जोड़ता है।

  • binary relationship दो वर्गों की वस्तुओं को जोड़ता है।

  • ternary relationship तीन या अधिक वर्गों की वस्तुओं को जोड़ता है।

संघों के कार्डिनलिटी अनुपात

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

  • One–to–One - कक्षा A की एक एकल वस्तु वर्ग B की एकल वस्तु से जुड़ी है।

  • One–to–Many - कक्षा A की एक एकल वस्तु वर्ग B की कई वस्तुओं से जुड़ी है।

  • Many–to–Many - कक्षा A की एक वस्तु कक्षा B की कई वस्तुओं से जुड़ी हो सकती है और इसके विपरीत कक्षा B की एक वस्तु कक्षा A की कई वस्तुओं से जुड़ी हो सकती है।

एकत्रीकरण या रचना

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

Example

रिश्ते में, "एक कार में एक मोटर होती है", कार पूरी वस्तु या समुच्चय है, और मोटर कार का "भाग" है। एकत्रीकरण निरूपित कर सकता है -

  • Physical containment - उदाहरण, एक कंप्यूटर मॉनिटर, सीपीयू, माउस, कीबोर्ड और इसी तरह से बना है।

  • Conceptual containment - उदाहरण, शेयरधारक का एक हिस्सा है।

ऑब्जेक्ट मॉडल के लाभ

अब जब हम वस्तु अभिविन्यास से संबंधित मुख्य अवधारणाओं से गुजरे हैं, तो इस मॉडल को पेश किए जाने वाले लाभों को नोट करना सार्थक होगा।

ऑब्जेक्ट मॉडल का उपयोग करने के लाभ हैं -

  • यह सॉफ्टवेयर के तेजी से विकास में मदद करता है।

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

  • यह अपेक्षाकृत परेशानी मुक्त उन्नयन का समर्थन करता है।

  • यह वस्तुओं, डिजाइनों और कार्यों का पुन: उपयोग करने में सक्षम बनाता है।

  • यह विकास के खतरों को कम करता है, विशेष रूप से जटिल प्रणालियों के एकीकरण में।

हम जानते हैं कि ऑब्जेक्ट-ओरिएंटेड मॉडलिंग (ओओएम) तकनीक वस्तुओं के आसपास आयोजित मॉडल का उपयोग करके किसी एप्लिकेशन में चीजों को दर्शाती है। कोई भी सॉफ्टवेयर विकास दृष्टिकोण निम्नलिखित चरणों से गुजरता है -

  • Analysis,
  • आकृति दें और
  • Implementation.

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

ऑब्जेक्ट ओरिएंटेड सॉफ्टवेयर डेवलपमेंट में चरण

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

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

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

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

ऑब्जेक्ट-ओरिएंटेड डिज़ाइन में दो मुख्य चरण शामिल हैं, अर्थात्, सिस्टम डिज़ाइन और ऑब्जेक्ट डिज़ाइन।

System Design

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

Object Design

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

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

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

ऑब्जेक्ट-ओरिएंटेड इम्प्लीमेंटेशन एंड टेस्टिंग

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

ऑब्जेक्ट-ओरिएंटेड सिस्टम के सिद्धांत

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

Major Elements- प्रमुख रूप से, इसका मतलब यह है कि यदि किसी मॉडल में इन तत्वों में से कोई एक नहीं है, तो यह ऑब्जेक्ट ओरिएंटेड होना बंद कर देता है। चार प्रमुख तत्व हैं -

  • Abstraction
  • Encapsulation
  • Modularity
  • Hierarchy

Minor Elements- मामूली रूप से, इसका मतलब है कि ये तत्व उपयोगी हैं, लेकिन ऑब्जेक्ट मॉडल का अपरिहार्य हिस्सा नहीं है। तीन छोटे तत्व हैं -

  • Typing
  • Concurrency
  • Persistence

मतिहीनता

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

ग्रेडी बूच ने अमूर्तता को इस प्रकार परिभाषित किया है -

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

Example - जब एक कक्षा के छात्र को डिज़ाइन किया जाता है, तो विशेषताओं enrolment_number, नाम, पाठ्यक्रम और पते को शामिल किया जाता है, जबकि pul_rate और size_of_shoe जैसी विशेषताओं को समाप्त कर दिया जाता है, क्योंकि वे शैक्षणिक संस्थान के परिप्रेक्ष्य में अप्रासंगिक हैं।

कैप्सूलीकरण

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

प्रतिरूपकता

मोड्यूलरिटी किसी समस्या (प्रोग्राम) को मॉड्यूल के एक सेट में विघटित करने की प्रक्रिया है ताकि समस्या की समग्र जटिलता को कम किया जा सके। बूच ने प्रतिरूपकता को इस प्रकार परिभाषित किया है -

"प्रतिरूपकता एक ऐसी प्रणाली की संपत्ति है जिसे समरूप और शिथिल युग्मित मॉड्यूल के एक सेट में विघटित किया गया है।"

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

अनुक्रम

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

OOA में दो प्रकार की पदानुक्रम हैं -

  • “IS–A” hierarchy- यह वंशानुगत संबंध को वंशानुक्रम में परिभाषित करता है, जिससे एक सुपर-क्लास से, कई उपवर्ग प्राप्त हो सकते हैं, जिनमें फिर से उपवर्ग हो सकते हैं और इसी तरह। उदाहरण के लिए, यदि हम एक क्लास रोज को क्लास फ्लावर से निकालते हैं, तो हम कह सकते हैं कि एक गुलाब “एक” फूल है।

  • “PART–OF” hierarchy- यह एकत्रीकरण में पदानुक्रमित संबंध को परिभाषित करता है जिसके द्वारा एक वर्ग अन्य वर्गों से बना हो सकता है। उदाहरण के लिए, एक फूल सीपल्स, पंखुड़ियों, पुंकेसर और कार्पेल से बना है। यह कहा जा सकता है कि एक पंखुड़ी "फूल का एक हिस्सा" है।

टाइपिंग

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

टाइपिंग के दो प्रकार हैं -

  • Strong Typing - यहां, एक ऑब्जेक्ट पर ऑपरेशन को संकलन के समय जांचा जाता है, जैसा कि प्रोग्रामिंग भाषा एफिल में है।

  • Weak Typing- यहां, संदेश किसी भी वर्ग को भेजे जा सकते हैं। ऑपरेशन को निष्पादन के समय ही जांचा जाता है, जैसा कि प्रोग्रामिंग भाषा स्मॉलटाक में होता है।

संगामिति

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

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

हठ

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

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

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

ऑब्जेक्ट मॉडलिंग

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

ऑब्जेक्ट मॉडलिंग की प्रक्रिया को निम्नलिखित चरणों में देखा जा सकता है -

  • वस्तुओं और समूह को कक्षाओं में पहचानें
  • वर्गों के बीच संबंधों को पहचानें
  • उपयोगकर्ता ऑब्जेक्ट मॉडल आरेख बनाएं
  • उपयोगकर्ता ऑब्जेक्ट विशेषताओं को परिभाषित करें
  • उन कार्यों को परिभाषित करें जिन्हें कक्षाओं पर किया जाना चाहिए
  • समीक्षा शब्दावली

डायनामिक मॉडलिंग

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

डायनेमिक मॉडलिंग को "किसी व्यक्ति द्वारा घटनाओं के प्रति प्रतिक्रिया व्यक्त करने के तरीके, या तो बाहरी वस्तुओं द्वारा ट्रिगर की गई आंतरिक घटनाओं, या बाहरी दुनिया द्वारा ट्रिगर की गई बाहरी घटनाओं" के रूप में वर्णित करने का एक तरीका के रूप में परिभाषित किया जा सकता है।

गतिशील मॉडलिंग की प्रक्रिया को निम्नलिखित चरणों में देखा जा सकता है -

  • प्रत्येक वस्तु की अवस्थाओं को पहचानें
  • घटनाओं को पहचानें और कार्यों की प्रयोज्यता का विश्लेषण करें
  • डायनामिक मॉडल आरेख का निर्माण, जिसमें राज्य संक्रमण आरेख शामिल हैं
  • ऑब्जेक्ट विशेषताओं के संदर्भ में प्रत्येक राज्य को व्यक्त करें
  • तैयार किए गए राज्य-संक्रमण आरेखों को मान्य करें

कार्यात्मक मॉडलिंग

कार्यात्मक मॉडलिंग वस्तु-उन्मुख विश्लेषण का अंतिम घटक है। क्रियात्मक मॉडल उन प्रक्रियाओं को दिखाता है जो किसी ऑब्जेक्ट के भीतर की जाती हैं और तरीकों के बीच बढ़ने पर डेटा कैसे बदलता है। यह ऑब्जेक्ट मॉडलिंग के संचालन और गतिशील मॉडलिंग की क्रियाओं के अर्थ को निर्दिष्ट करता है। कार्यात्मक मॉडल पारंपरिक संरचित विश्लेषण के डेटा प्रवाह आरेख से मेल खाती है।

कार्यात्मक मॉडलिंग की प्रक्रिया को निम्नलिखित चरणों में देखा जा सकता है -

  • सभी इनपुट और आउटपुट को पहचानें
  • कार्यात्मक निर्भरता दिखाने वाले डेटा प्रवाह आरेख का निर्माण करते हैं
  • प्रत्येक फ़ंक्शन का उद्देश्य बताएं
  • बाधाओं की पहचान करें
  • अनुकूलन मानदंड निर्दिष्ट करें

संरचित विश्लेषण बनाम वस्तु उन्मुख विश्लेषण

संरचित विश्लेषण / संरचित डिजाइन (एसएएसडी) दृष्टिकोण जलप्रपात मॉडल के आधार पर सॉफ्टवेयर विकास का पारंपरिक दृष्टिकोण है। एसएएसडी का उपयोग कर एक प्रणाली के विकास के चरण हैं -

  • व्यवहार्यता अध्ययन
  • आवश्यकता विश्लेषण और विशिष्टता
  • प्रणाली की रूपरेखा
  • Implementation
  • लागू करने की समीक्षा पोस्ट करें

अब, हम संरचित विश्लेषण दृष्टिकोण और वस्तु-उन्मुख विश्लेषण दृष्टिकोण के सापेक्ष फायदे और नुकसान को देखेंगे।

ऑब्जेक्ट ओरिएंटेड विश्लेषण के लाभ / नुकसान

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

संरचित विश्लेषण के लाभ / नुकसान

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

गतिशील मॉडल एक प्रणाली के समय पर निर्भर पहलुओं का प्रतिनिधित्व करता है। यह एक प्रणाली में वस्तुओं के राज्यों में अस्थायी परिवर्तन से संबंधित है। मुख्य अवधारणाएँ हैं -

  • राज्य, जो किसी वस्तु के जीवनकाल के दौरान एक विशेष स्थिति में स्थिति है।

  • संक्रमण, राज्य में बदलाव

  • घटना, एक घटना जो संक्रमण को ट्रिगर करती है

  • कार्रवाई, एक निर्बाध और परमाणु गणना जो किसी घटना के कारण होती है, और

  • बदलाव की संगति।

एक राज्य मशीन एक वस्तु के व्यवहार को मॉडल करती है क्योंकि यह कुछ घटनाओं के साथ-साथ घटनाओं के कारण होने वाली क्रियाओं के कारण अपने जीवनकाल में कई राज्यों से गुजरती है। एक राज्य मशीन ग्राफिकल रूप से एक राज्य संक्रमण आरेख के माध्यम से दर्शायी जाती है।

राज्य और राज्य परिवर्तन

राज्य

राज्य एक विशेषता है जो किसी विशेष समय अवधि में वस्तु के मूल्यों द्वारा दी गई अमूर्तता है। यह एक वस्तु के जीवनकाल में परिमित समय अवधि के लिए होने वाली स्थिति है, जिसमें यह कुछ शर्तों को पूरा करता है, कुछ गतिविधियों को करता है, या कुछ घटनाओं के होने की प्रतीक्षा करता है। राज्य संक्रमण आरेखों में, एक राज्य को गोल आयतों द्वारा दर्शाया जाता है।

किसी राज्य के हिस्से

  • Name- एक स्ट्रिंग एक राज्य को दूसरे से अलग करती है। किसी राज्य का कोई नाम नहीं हो सकता है।

  • Entry/Exit Actions - यह राज्य में प्रवेश करने और बाहर निकलने पर की गई गतिविधियों को दर्शाता है।

  • Internal Transitions - एक राज्य के भीतर परिवर्तन जो राज्य में परिवर्तन का कारण नहीं बनता है।

  • Sub–states - राज्यों के भीतर।

प्रारंभिक और अंतिम राज्य

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

TRANSITION

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

एक संक्रमण के पाँच भाग हैं -

  • Source State - संक्रमण से प्रभावित राज्य।

  • Event Trigger - वह स्थिति जिसके कारण स्रोत राज्य में कोई वस्तु एक संक्रमण से गुजरती है यदि गार्ड की स्थिति संतुष्ट है।

  • Guard Condition - एक बूलियन अभिव्यक्ति जो कि ट्रू होने पर, इवेंट ट्रिगर प्राप्त करने पर संक्रमण का कारण बनती है।

  • Action - एक गैर-रुकावट और परमाणु गणना जो किसी घटना के कारण स्रोत वस्तु पर होती है।

  • Target State - संक्रमण के पूरा होने के बाद गंतव्य राज्य।

Example

मान लीजिए कि कोई व्यक्ति X को Y की जगह लेने के लिए टैक्सी ले रहा है। व्यक्ति के राज्य हो सकते हैं: प्रतीक्षारत (टैक्सी का इंतजार), राइडिंग (उसे एक टैक्सी मिल गई है और उसमें यात्रा कर रहा है), और पहुंच गया (वह पहुँच गया है) गंतव्य)। निम्नलिखित आंकड़ा राज्य संक्रमण को दर्शाता है।

आयोजन

घटनाएँ कुछ घटनाएँ होती हैं जो किसी वस्तु या वस्तुओं के समूह के राज्य संक्रमण को ट्रिगर कर सकती हैं। घटनाओं का समय और स्थान में स्थान होता है, लेकिन इसके साथ कोई समयावधि नहीं जुड़ी होती है। घटनाएँ आम तौर पर कुछ कार्यों से जुड़ी होती हैं।

घटनाओं के उदाहरण हैं माउस क्लिक, की प्रेस, एक इंटरप्ट, स्टैक ओवरफ्लो आदि।

राज्य आरेखों में संक्रमण के चाप के साथ संक्रमण को ट्रिगर करने वाली घटनाओं को लिखा जाता है।

Example

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

बाहरी और आंतरिक घटनाएँ

बाहरी घटनाएं वे घटनाएं हैं जो सिस्टम के उपयोगकर्ता से सिस्टम के भीतर वस्तुओं तक जाती हैं। उदाहरण के लिए, उपयोगकर्ता द्वारा माउस क्लिक या कुंजी। प्रेस बाहरी घटनाएँ हैं।

आंतरिक घटनाएं वे हैं जो एक सिस्टम से एक ऑब्जेक्ट से दूसरी ऑब्जेक्ट में गुजरती हैं। उदाहरण के लिए, स्टैक ओवरफ्लो, एक विभाजन त्रुटि, आदि।

स्थगित घटनाएँ

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

इवेंट क्लासेस

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

Flight_Departs (Flight_No, From_City, To_City, मार्ग)

कार्रवाई

गतिविधि

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

कार्य

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

प्रवेश और बाहर निकलने की क्रिया

प्रवेश क्रिया वह क्रिया है जिसे किसी अवस्था में प्रवेश करने पर क्रियान्वित किया जाता है, भले ही उसमें परिवर्तन क्यों न हो।

इसी तरह, एक अवस्था को छोड़ते समय जिस क्रिया को अंजाम दिया जाता है, भले ही इससे जो संक्रमण हुआ हो, उसे बाहर निकलने की क्रिया कहा जाता है।

परिदृश्य

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

डायनामिक मॉडलिंग के लिए आरेख

दो प्राथमिक चित्र हैं जिनका उपयोग गतिशील मॉडलिंग के लिए किया जाता है -

सहभागिता डायग्राम

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

  • Sequence Diagram - यह एक सारणीबद्ध तरीके से संदेशों के अस्थायी आदेश का प्रतिनिधित्व करता है।

  • Collaboration Diagram - यह उन वस्तुओं के संरचनात्मक संगठन का प्रतिनिधित्व करता है जो कोने और चाप के माध्यम से संदेश भेजते हैं और प्राप्त करते हैं।

राज्य संक्रमण आरेख

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

घटनाओं की संगति

एक प्रणाली में, दो प्रकार की संगामिति मौजूद हो सकती है। वे हैं -

सिस्टम कंसीडर

यहां, सिस्टम लेवल में कंसीलर मॉडलिंग की जाती है। समग्र प्रणाली को राज्य मशीनों के एकत्रीकरण के रूप में तैयार किया जाता है, जहां प्रत्येक राज्य मशीन दूसरों के साथ समवर्ती रूप से निष्पादित होती है।

किसी वस्तु के भीतर समरूपता

यहां, कोई ऑब्जेक्ट समवर्ती घटनाओं को जारी कर सकता है। एक वस्तु में ऐसे राज्य हो सकते हैं जो उप-राज्यों से बने होते हैं, और प्रत्येक उप-राज्यों में समवर्ती घटनाएं हो सकती हैं।

किसी वस्तु के भीतर संगति से संबंधित अवधारणाएं इस प्रकार हैं -

सरल और समग्र राज्य

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

समग्र राज्यों में या तो अनुक्रमिक उप-राज्य या समवर्ती उप-राज्य हो सकते हैं।

अनुक्रमिक उप-राज्य

अनुक्रमिक उप-राज्यों में, निष्पादन का नियंत्रण क्रमिक तरीके से एक के बाद एक उप-राज्य से दूसरे उप-राज्य में गुजरता है। इन राज्यों की मशीनों में एक प्रारंभिक राज्य और एक अंतिम स्थिति होती है।

निम्नलिखित आंकड़ा अनुक्रमिक उप-राज्यों की अवधारणा को दिखाता है।

समवर्ती उप-राज्य

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

निम्नलिखित आंकड़ा समवर्ती उप-राज्यों की अवधारणा को दर्शाता है।

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

डेटा फ्लो आरेख

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

रंबा एट अल। DFD के रूप में परिभाषित किया गया है, "एक डेटा प्रवाह आरेख एक ग्राफ है जो डेटा स्रोतों से डेटा मानों के प्रवाह को प्रक्रियाओं के माध्यम से वस्तुओं में दिखाता है जो उन्हें अन्य वस्तुओं पर अपने गंतव्य में बदल देता है।"

DFD के चार मुख्य भाग हैं -

  • Processes,
  • डेटा प्रवाह,
  • अभिनेता, और
  • डेटा स्टोर।

DFD के अन्य भाग हैं -

  • अड़चनें, और
  • नियंत्रण प्रवाह।

एक DFD की विशेषताएं

प्रक्रियाओं

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

Representation in DFD - एक प्रक्रिया को इसके नाम के साथ एक दीर्घवृत्त के रूप में दर्शाया जाता है और इसमें निश्चित संख्या में इनपुट और आउटपुट डेटा मान होते हैं।

Example - निम्न आंकड़ा एक प्रक्रिया को दर्शाता है Compute_HCF_LCM जो दो पूर्णांकों को इनपुट के रूप में स्वीकार करता है और उनके HCF (उच्चतम सामान्य कारक) और LCM (कम से कम सामान्य एकाधिक) को आउटपुट करता है।

डेटा प्रवाह

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

Representation in DFD - डेटा प्रवाह को एक निर्देशित चाप या तीर द्वारा दर्शाया जाता है, जो उस डेटा आइटम के नाम के साथ लेबल किया जाता है जिसे वह करता है।

उपरोक्त आंकड़ों में, Integer_a और Integer_b इस प्रक्रिया में इनपुट डेटा प्रवाह का प्रतिनिधित्व करते हैं, जबकि LCM और HCF आउटपुट डेटा प्रवाह हैं।

निम्नलिखित मामलों में एक डेटा प्रवाह को कांटा जा सकता है -

  • आउटपुट मान कई स्थानों पर भेजा जाता है जैसा कि निम्न आकृति में दिखाया गया है। यहाँ, आउटपुट एरो को अनब्लॉक किया जाता है क्योंकि वे समान मान को दर्शाते हैं।

  • डेटा प्रवाह में एक समग्र मूल्य होता है, और प्रत्येक घटक को विभिन्न स्थानों पर भेजा जाता है जैसा कि निम्न आकृति में दिखाया गया है। यहां, प्रत्येक फोर्क किए गए घटकों को लेबल किया गया है।

अभिनेताओं

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

Representation in DFD- एक अभिनेता को एक आयत द्वारा दर्शाया जाता है। अभिनेता इनपुट और आउटपुट से जुड़े होते हैं और DFD की सीमा पर झूठ बोलते हैं।

Example - निम्नलिखित आंकड़ा एक काउंटर बिक्री प्रणाली में अभिनेताओं, अर्थात्, ग्राहक और Sales_Clerk को दर्शाता है।

डेटा स्टोर

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

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

Example- निम्नलिखित आंकड़ा एक डेटा स्टोर, Sales_Record दिखाता है, जो सभी बिक्री का विवरण संग्रहीत करता है। डेटा स्टोर पर इनपुट में बिक्री के विवरण जैसे कि आइटम, बिलिंग राशि, दिनांक, आदि शामिल हैं। औसत बिक्री खोजने के लिए, प्रक्रिया बिक्री रिकॉर्ड को पुनर्प्राप्त करती है और औसत की गणना करती है।

प्रतिबन्ध

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

  • ऑब्जेक्ट मॉडलिंग में, बाधाएं वस्तुओं के बीच संबंध को परिभाषित करती हैं। वे विभिन्न मूल्यों के बीच संबंध को भी परिभाषित कर सकते हैं जो एक वस्तु अलग-अलग समय पर हो सकती है।

  • डायनामिक मॉडलिंग में, बाधाएं विभिन्न वस्तुओं के राज्यों और घटनाओं के बीच संबंध को परिभाषित करती हैं।

  • फ़ंक्शनल मॉडलिंग में, बाधाएँ परिवर्तनों और गणनाओं पर प्रतिबंध को परिभाषित करती हैं।

Representation - एक बाधा ब्रेसिज़ के भीतर एक स्ट्रिंग के रूप में प्रदान की जाती है।

Example- निम्नलिखित आंकड़ा एक कंपनी के कर्मचारियों के वेतन की गणना के लिए DFD का एक हिस्सा दिखाता है जिसने बिक्री विभाग के सभी कर्मचारियों को प्रोत्साहन देने और मानव संसाधन विभाग के सभी कर्मचारियों के वेतन में वृद्धि का फैसला किया है। यह देखा जा सकता है कि बाधा {विभाग: बिक्री} प्रोत्साहन की गणना केवल तभी की जाती है जब विभाग बिक्री कर रहा हो और बाधा {विभाग: मानव संसाधन} बढ़ाना हो तभी गणना की जाती है यदि विभाग एचआर है।

नियंत्रण प्रवाह

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

Representation in DFD - नियंत्रण प्रवाह का प्रतिनिधित्व एक बिंदीदार चाप द्वारा किया जाता है, जो बूलियन मूल्य को उनके द्वारा नियंत्रित प्रक्रिया में उत्पन्न करता है।

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

एक प्रणाली के DFD मॉडल का विकास करना

एक प्रणाली के DFD मॉडल को विकसित करने के लिए, DFD के एक पदानुक्रम का निर्माण किया जाता है। शीर्ष स्तर के DFD में एक एकल प्रक्रिया और इसके साथ सहभागिता करने वाले कलाकार शामिल होते हैं।

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

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

थोक सॉफ्टवेयर के लिए कार्यात्मक मॉडल नीचे दिया गया है। नीचे दिया गया आंकड़ा शीर्ष-स्तरीय DFD दिखाता है। यह एक एकल प्रक्रिया के रूप में सॉफ्टवेयर को दिखाता है और इसके साथ बातचीत करने वाले अभिनेता।

सिस्टम में अभिनेता हैं -

  • Customers
  • Salesperson
  • Proprietor

अगले स्तर DFD में, जैसा कि निम्नलिखित आंकड़े में दिखाया गया है, सिस्टम की प्रमुख प्रक्रियाओं की पहचान की जाती है, डेटा स्टोर परिभाषित किए जाते हैं और अभिनेताओं के साथ प्रक्रियाओं की बातचीत, और डेटा स्टोर स्थापित होते हैं।

प्रणाली में, तीन प्रक्रियाओं को पहचाना जा सकता है, जो हैं -

  • ग्राहक पंजीकृत करें
  • प्रक्रिया बिक्री
  • उपहारों का पता लगाएं

आवश्यक डेटा स्टोर हैं -

  • उपभोक्ता विवरण
  • बिक्री विवरण
  • उपहार का विवरण

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

निम्न आंकड़ा पता लगाने की प्रक्रिया के विस्तार को दर्शाता है। इसमें दो प्रक्रियाएँ हैं, कुल बिक्री और निर्णय प्रकार का उपहार सिक्का खोजें। कुल बिक्री प्रक्रिया खोजें प्रत्येक ग्राहक के अनुरूप वार्षिक कुल बिक्री की गणना करता है और डेटा को रिकॉर्ड करता है। इस रिकॉर्ड और प्रोप्राइटर के फैसले को इनपुट के रूप में लेते हुए, गिफ्ट के सिक्कों को Decide Type of Gift Coin प्रक्रिया के माध्यम से आवंटित किया जाता है।

DFD के लाभ और नुकसान

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

ऑब्जेक्ट, डायनेमिक और फ़ंक्शनल मॉडल के बीच संबंध

ऑब्जेक्ट मॉडल, डायनामिक मॉडल और फंक्शनल मॉडल एक पूर्ण ऑब्जेक्ट-ओरिएंटेड विश्लेषण के लिए एक दूसरे के पूरक हैं।

  • ऑब्जेक्ट मॉडलिंग वस्तुओं के संदर्भ में सॉफ्टवेयर सिस्टम की स्थैतिक संरचना को विकसित करता है। इस प्रकार यह एक प्रणाली के "कर्ता" को दर्शाता है।

  • डायनामिक मॉडलिंग बाहरी घटनाओं की प्रतिक्रिया में वस्तुओं के लौकिक व्यवहार को विकसित करता है। यह वस्तुओं पर किए गए संचालन के अनुक्रम को दर्शाता है।

  • कार्यात्मक मॉडल सिस्टम को क्या करना चाहिए, इसका अवलोकन देता है।

फंक्शनल मॉडल और ऑब्जेक्ट मॉडल

ऑब्जेक्ट मॉडल के संदर्भ में एक कार्यात्मक मॉडल के चार मुख्य भाग हैं -

  • Process - प्रक्रियाएं उन वस्तुओं के तरीकों को बताती हैं जिन्हें लागू करने की आवश्यकता है।

  • Actors - एक्टर्स ऑब्जेक्ट मॉडल में ऑब्जेक्ट हैं।

  • Data Stores - ये या तो ऑब्जेक्ट मॉडल में ऑब्जेक्ट हैं या ऑब्जेक्ट्स की विशेषताएँ हैं।

  • Data Flows- डेटा प्रवाह अभिनेताओं से या वस्तुओं से या पर कार्रवाई का प्रतिनिधित्व करता है। डेटा प्रवाह या डेटा स्टोर से डेटा प्रश्नों या अद्यतनों का प्रतिनिधित्व करता है।

कार्यात्मक मॉडल और गतिशील मॉडल

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

ऑब्जेक्ट मॉडल और गतिशील मॉडल

गतिशील मॉडल वस्तुओं की स्थिति और घटनाओं की घटनाओं और राज्यों में बाद के परिवर्तनों पर किए गए कार्यों को दर्शाता है। परिवर्तनों के परिणामस्वरूप ऑब्जेक्ट की स्थिति ऑब्जेक्ट मॉडल में दिखाई जाती है।

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

संक्षिप्त इतिहास

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

यूएमएल में सिस्टम और मॉडल

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

Model - मॉडल एक प्रणाली का सरलीकृत, पूर्ण और सुसंगत अमूर्तन है, जो प्रणाली की बेहतर समझ के लिए बनाया गया है।

View - एक दृश्य एक विशिष्ट दृष्टिकोण से सिस्टम के मॉडल का एक प्रक्षेपण है।

यूएमएल का वैचारिक मॉडल

यूएमएल का वैचारिक मॉडल तीन प्रमुख तत्वों को शामिल करता है -

  • बुनियादी इमारत ब्लॉकों
  • Rules
  • सामान्य तंत्र

बेसिक बिल्डिंग ब्लॉक्स

यूएमएल के तीन भवन खंड हैं -

  • Things
  • Relationships
  • Diagrams

चीज़ें

यूएमएल में चार तरह की चीजें हैं, जैसे -

  • Structural Things- ये यूएमएल मॉडल की संज्ञाएं हैं जो स्थिर तत्वों का प्रतिनिधित्व करते हैं जो भौतिक या वैचारिक हो सकते हैं। संरचनात्मक चीजें वर्ग, इंटरफ़ेस, सहयोग, उपयोग मामला, सक्रिय वर्ग, घटक और नोड्स हैं।

  • Behavioral Things- ये समय और स्थान पर गतिशील व्यवहार का प्रतिनिधित्व करने वाले यूएमएल मॉडल की क्रियाएं हैं। दो प्रकार की व्यवहार संबंधी बातें परस्पर क्रिया और राज्य मशीन हैं।

  • Grouping Things- इनमें यूएमएल मॉडल के संगठनात्मक भाग शामिल हैं। केवल एक प्रकार की समूहीकरण की चीज है, अर्थात, पैकेज।

  • Annotational Things - ये तत्वों का वर्णन करने के लिए लागू टिप्पणियों का प्रतिनिधित्व करने वाले यूएमएल मॉडल में स्पष्टीकरण हैं।

रिश्तों

रिश्ते चीजों के बीच संबंध हैं। UML में जिन चार प्रकार के रिश्तों का प्रतिनिधित्व किया जा सकता है वे हैं -

  • Dependency- यह दो चीजों के बीच एक शब्दार्थ संबंध है जैसे कि एक चीज में बदलाव दूसरे में बदलाव लाता है। पूर्व स्वतंत्र चीज है, जबकि बाद वाली निर्भर चीज है।

  • Association - यह एक संरचनात्मक संबंध है जो सामान्य संरचना और सामान्य व्यवहार वाले लिंक के समूह का प्रतिनिधित्व करता है।

  • Generalization - यह एक सामान्यीकरण / विशेषज्ञता संबंध का प्रतिनिधित्व करता है जिसमें उपवर्गों को सुपर-क्लास से संरचना और व्यवहार प्राप्त होता है।

  • Realization - यह दो या दो से अधिक क्लासीफायर के बीच एक शब्दार्थ संबंध होता है जैसे कि एक क्लासिफायर एक अनुबंध को देता है जिसे अन्य क्लासिफायर द्वारा पालन करना सुनिश्चित किया जाता है।

चित्र

आरेख एक प्रणाली का चित्रमय प्रतिनिधित्व है। इसमें आमतौर पर एक ग्राफ के रूप में तत्वों का एक समूह शामिल होता है। यूएमएल में नौ आरेख शामिल हैं, अर्थात् -

  • कक्षा आरेख
  • वस्तु आरेख
  • स्थिति चित्र का उपयोग
  • अनुक्रम आरेख
  • सहयोग आरेख
  • राज्य चार्ट आरेख
  • गतिविधि आरेख
  • घटक आरेख
  • परिनियोजन आरेख

नियमों

यूएमएल के कई नियम हैं ताकि मॉडल सामंजस्यपूर्ण रूप से आत्मनिर्भर हों और सिस्टम में अन्य मॉडलों के साथ सामंजस्यपूर्ण रूप से संबंधित हों। यूएमएल में निम्नलिखित के लिए शब्दार्थ नियम हैं -

  • Names
  • Scope
  • Visibility
  • Integrity
  • Execution

सामान्य तंत्र

यूएमएल के चार सामान्य तंत्र हैं -

  • Specifications
  • Adornments
  • सामान्य विभाग
  • एक्स्टेंसिबिलिटी मैकेनिज्म

विशेष विवरण

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

श्रंगार

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

सामान्य विभाग

ऑब्जेक्ट-ओरिएंटेड सिस्टम को कई तरीकों से विभाजित किया जा सकता है। विभाजन के दो सामान्य तरीके हैं -

  • Division of classes and objects- एक वर्ग समान वस्तुओं के समूह का एक अमूर्तन है। ऑब्जेक्ट एक ठोस उदाहरण है जिसका सिस्टम में वास्तविक अस्तित्व है।

  • Division of Interface and Implementation- एक इंटरफ़ेस इंटरैक्शन के नियमों को परिभाषित करता है। कार्यान्वयन इंटरफ़ेस में परिभाषित नियमों का ठोस अहसास है।

एक्स्टेंसिबिलिटी मैकेनिज्म

यूएमएल एक ओपन एंडेड भाषा है। एक प्रणाली की आवश्यकताओं के अनुरूप यूएमएल की क्षमताओं को नियंत्रित तरीके से विस्तारित करना संभव है। एक्स्टेंसिबिलिटी मैकेनिज्म हैं -

  • Stereotypes - यह यूएमएल की शब्दावली का विस्तार करता है, जिसके माध्यम से नए बिल्डिंग ब्लॉक मौजूदा लोगों से बनाए जा सकते हैं।

  • Tagged Values - यह यूएमएल बिल्डिंग ब्लॉक्स के गुणों का विस्तार करता है।

  • Constraints - यह यूएमएल बिल्डिंग ब्लॉकों के शब्दार्थ का विस्तार करता है।

UML भवन ब्लॉकों में से प्रत्येक के लिए विशिष्ट अंकन को परिभाषित करता है।

कक्षा

एक वर्ग को तीन वर्गों वाले एक आयत द्वारा दर्शाया जाता है -

  • वर्ग के नाम वाला शीर्ष भाग
  • वर्ग विशेषताओं वाले मध्य खंड
  • नीचे अनुभाग वर्ग के संचालन का प्रतिनिधित्व करता है

विशेषताओं और संचालन की दृश्यता को निम्नलिखित तरीकों से दर्शाया जा सकता है -

  • Public- एक सार्वजनिक सदस्य सिस्टम में कहीं से भी दिखाई देता है। वर्ग आरेख में, यह प्रतीक '+' द्वारा उपसर्ग किया जाता है।

  • Private- एक निजी सदस्य केवल कक्षा के भीतर से ही दिखाई देता है। इसे कक्षा के बाहर से एक्सेस नहीं किया जा सकता है। एक निजी सदस्य '-' के प्रतीक द्वारा उपसर्ग करता है।

  • Protected- एक संरक्षित सदस्य वर्ग के भीतर और इस वर्ग से विरासत में मिले उपवर्गों से दिखाई देता है, लेकिन बाहर से नहीं। यह प्रतीक '#' से उपसर्ग करता है।

एक अमूर्त वर्ग का वर्ग नाम इटैलिक्स में लिखा गया है।

Example- आइए पहले शुरू किए गए सर्किल वर्ग पर विचार करें। सर्कल की विशेषताएँ x- समन्वय, y- समन्वय और त्रिज्या हैं। संचालन findArea (), findCircumference (), और स्केल () हैं। आइए हम मान लें कि x- समन्वय और y- समन्वय निजी डेटा सदस्य हैं, त्रिज्या एक संरक्षित डेटा सदस्य है, और सदस्य फ़ंक्शन सार्वजनिक हैं। निम्नलिखित आंकड़ा वर्ग का आरेखीय प्रतिनिधित्व देता है।

वस्तु

एक वस्तु को दो वर्गों के साथ एक आयत के रूप में दर्शाया जाता है -

  • शीर्ष खंड में उस वस्तु का नाम होता है जिसमें कक्षा या पैकेज का नाम होता है जिसका वह उदाहरण है। नाम निम्नलिखित रूप लेता है -

    • object-name - वर्ग-नाम

    • object-name - वर्ग-नाम :: पैकेज-नाम

    • class-name - अनाम वस्तुओं के मामले में

  • नीचे का खंड विशेषताओं के मूल्यों का प्रतिनिधित्व करता है। यह प्रपत्र विशेषता-नाम = मान लेता है।

  • कभी-कभी वस्तुओं को गोल आयतों का उपयोग करके दर्शाया जाता है।

Example- आइए c1 नामक वर्ग वृत्त की एक वस्तु पर विचार करें। हम मानते हैं कि c1 का केंद्र (2, 3) पर है और c1 की त्रिज्या 5. है। निम्नलिखित आकृति में वस्तु को दर्शाया गया है।

अंग

एक घटक प्रणाली का एक भौतिक और बदली जाने वाला हिस्सा है जो इंटरफेस के एक सेट की प्राप्ति के अनुरूप है और प्रदान करता है। यह कक्षाओं और इंटरफेस जैसे तत्वों की भौतिक पैकेजिंग का प्रतिनिधित्व करता है।

Notation - यूएमएल आरेख में, एक घटक को एक आयत द्वारा टैब के साथ दर्शाया गया है जैसा कि नीचे दिए गए चित्र में दिखाया गया है।

इंटरफेस

इंटरफ़ेस एक वर्ग या घटक के तरीकों का एक संग्रह है। यह उन सेवाओं के सेट को निर्दिष्ट करता है जो कक्षा या घटक द्वारा प्रदान किए जा सकते हैं।

Notation- आम तौर पर, एक इंटरफ़ेस को उसके नाम के साथ एक सर्कल के रूप में तैयार किया जाता है। एक इंटरफ़ेस लगभग हमेशा उस वर्ग या घटक से जुड़ा होता है जो इसे महसूस करता है। निम्नलिखित आंकड़ा एक अंतरफलक की सूचना देता है।

पैकेज

पैकेज तत्वों का एक संगठित समूह है। एक पैकेज में क्लास, कंपोनेंट और अन्य पैकेज जैसी संरचनात्मक चीजें शामिल हो सकती हैं।

Notation- रेखांकन, एक पैकेज एक tabbed फ़ोल्डर द्वारा प्रतिनिधित्व किया है। एक पैकेज आम तौर पर केवल अपने नाम के साथ तैयार किया जाता है। हालाँकि इसमें पैकेज की सामग्री के बारे में अतिरिक्त विवरण हो सकता है। निम्नलिखित आंकड़े देखें।

संबंध

विभिन्न प्रकार के रिश्तों की सूचना इस प्रकार है -

आमतौर पर, रिश्ते में तत्व रिश्ते में विशिष्ट भूमिका निभाते हैं। एक भूमिका नाम एक निश्चित संदर्भ में भाग लेने वाले तत्व के व्यवहार को दर्शाता है।

Example- निम्नलिखित आंकड़े कक्षाओं के बीच विभिन्न संबंधों के उदाहरण दिखाते हैं। पहला आंकड़ा दो वर्गों, विभाग और कर्मचारी के बीच एक जुड़ाव को दर्शाता है, जिसमें एक विभाग में कई कर्मचारी काम कर सकते हैं। कार्यकर्ता भूमिका नाम है। विभाग के साथ '1' और कर्मचारी के साथ '*' यह दर्शाते हैं कि कार्डिनलिटी अनुपात एक से कई है। दूसरा आंकड़ा एकत्रीकरण संबंधों को चित्रित करता है, एक विश्वविद्यालय कई विभागों का "संपूर्ण" है।

यूएमएल संरचनात्मक आरेखों को निम्नानुसार वर्गीकृत किया गया है: वर्ग आरेख, वस्तु आरेख, घटक आरेख और परिनियोजन आरेख।

कक्षा आरेख

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

एक प्रणाली का वर्ग आरेख

आइए हम एक सरल बैंकिंग प्रणाली पर विचार करें।

एक बैंक की कई शाखाएँ होती हैं। प्रत्येक ज़ोन में, एक शाखा को ज़ोनल हेड ऑफिस के रूप में नामित किया जाता है जो उस ज़ोन की अन्य शाखाओं की निगरानी करता है। प्रत्येक शाखा में कई खाते और ऋण हो सकते हैं। एक खाता या तो एक बचत खाता या एक चालू खाता हो सकता है। एक ग्राहक बचत खाता और चालू खाता दोनों खोल सकता है। हालांकि, ग्राहक के पास एक से अधिक बचत खाता या चालू खाता नहीं होना चाहिए। एक ग्राहक बैंक से ऋण भी खरीद सकता है।

निम्नलिखित आंकड़ा इसी वर्ग आरेख को दर्शाता है।

सिस्टम में कक्षाएं

बैंक, शाखा, खाता, बचत खाता, चालू खाता, ऋण और ग्राहक।

रिश्तों

  • A Bank “has–a” number of Branches - रचना, एक-से-कई

  • A Branch with role Zonal Head Office supervises other Branches - एकतरफा सहयोग, एक-से-कई

  • A Branch “has–a” number of accounts - एकत्रीकरण, एक-से-कई

वर्ग खाते से, दो वर्गों को विरासत में मिला है, अर्थात् बचत खाता और चालू खाता।

  • A Customer can have one Current Account एसोसिएशन, एक-से-एक

  • A Customer can have one Savings Account एसोसिएशन, एक-से-एक

  • A Branch “has–a” number of Loans - एकत्रीकरण, एक-से-कई

  • A Customer can take many loans - एसोसिएशन, एक-से-कई

वस्तु आरेख

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

Example - निम्नलिखित आंकड़ा बैंकिंग प्रणाली के वर्ग आरेख के एक हिस्से का ऑब्जेक्ट आरेख दिखाता है।

घटक आरेख

घटक आरेख संगठन और घटकों के एक समूह के बीच निर्भरता दिखाते हैं।

घटक आरेखों में शामिल हैं -

  • Components
  • Interfaces
  • Relationships
  • पैकेज और सबसिस्टम (वैकल्पिक)

घटक आरेखों के लिए उपयोग किया जाता है -

  • आगे और रिवर्स इंजीनियरिंग के माध्यम से सिस्टम का निर्माण।

  • ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग लैंग्वेज का उपयोग करते हुए सिस्टम विकसित करते हुए सोर्स कोड फ़ाइलों का मॉडलिंग कॉन्फ़िगरेशन प्रबंधन।

  • मॉडलिंग डेटाबेस में स्कीमा का प्रतिनिधित्व करना।

  • गतिशील प्रणालियों के मॉडलिंग व्यवहार।

Example

निम्न आंकड़ा सिस्टम के स्रोत कोड को मॉडल करने के लिए एक घटक आरेख दिखाता है जो C ++ का उपयोग करके विकसित किया गया है। यह चार स्रोत कोड फ़ाइलों को दिखाता है, अर्थात्, myheader.h, otherheader.h, प्राथमिकता। Cpp, और other.cpp। Myheader.h के दो संस्करण दिखाए गए हैं, जो हाल के संस्करण से अपने पूर्वजों के लिए अनुरेखण है। फ़ाइल प्राथमिकता। Cpp में अन्य.cpp पर संकलन निर्भरता है। फ़ाइल अन्य.cpp में otherheader.h पर संकलन निर्भरता है।

परिनियोजन आरेख

एक परिनियोजन आरेख रनटाइम प्रोसेसिंग नोड्स के विन्यास और उनके घटकों पर जोर देता है जो उन पर रहते हैं। वे आमतौर पर नोड्स और निर्भरताओं, या नोड्स के बीच संघों के होते हैं।

परिनियोजन आरेख का उपयोग किया जाता है -

  • एम्बेडेड सिस्टम में मॉडल डिवाइस जिसमें आमतौर पर सॉफ्टवेयर के गहन संग्रह हार्डवेयर शामिल होते हैं।

  • क्लाइंट / सर्वर सिस्टम के टोपोलॉजी का प्रतिनिधित्व करते हैं।

  • मॉडल पूरी तरह से वितरित सिस्टम।

Example

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

UML व्यवहार आरेख एक प्रणाली के गतिशील पहलुओं को कल्पना, निर्दिष्ट, निर्माण और दस्तावेज करता है। व्यवहार आरेखों को निम्नानुसार वर्गीकृत किया गया है: केस आरेख, इंटरैक्शन आरेख, राज्य-चार्ट आरेख और गतिविधि आरेख का उपयोग करें।

केस मॉडल का उपयोग करें

उदाहरण

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

अभिनेता

एक अभिनेता उन भूमिकाओं का प्रतिनिधित्व करता है जो उपयोग के मामलों के उपयोगकर्ता निभाते हैं। एक अभिनेता एक व्यक्ति (जैसे छात्र, ग्राहक), एक उपकरण (जैसे कार्य केंद्र), या एक अन्य प्रणाली (जैसे बैंक, संस्थान) हो सकता है।

निम्नलिखित आंकड़ा छात्र नाम के एक अभिनेता की धारणा और जनरेट प्रदर्शन रिपोर्ट नामक एक उपयोग मामले को दर्शाता है।

केस आरेखों का उपयोग करें

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

केस डायग्राम का उपयोग करें -

  • बक्सों का इस्तेमाल करें
  • Actors
  • निर्भरता, सामान्यीकरण और संघ जैसे संबंध

उपयोग केस आरेख का उपयोग किया जाता है -

  • एक आयत के भीतर एक प्रणाली की सभी गतिविधियों को संलग्न करके एक प्रणाली के संदर्भ को मॉडल करने के लिए और इसके साथ बातचीत करके प्रणाली के बाहर के अभिनेताओं पर ध्यान केंद्रित करना।

  • बाहरी दृष्टिकोण से एक प्रणाली की आवश्यकताओं को मॉडल करने के लिए।

Example

आइए हम एक स्वचालित ट्रेडिंग हाउस सिस्टम पर विचार करें। हम सिस्टम की निम्नलिखित विशेषताएं मानते हैं -

  • ट्रेडिंग हाउस में दो प्रकार के ग्राहकों, व्यक्तिगत ग्राहकों और कॉर्पोरेट ग्राहकों के साथ लेनदेन होता है।

  • एक बार जब ग्राहक कोई ऑर्डर देता है, तो उसे बिक्री विभाग द्वारा संसाधित किया जाता है और ग्राहक को बिल दिया जाता है।

  • सिस्टम प्रबंधक को ग्राहक खातों का प्रबंधन करने और ग्राहक द्वारा पोस्ट किए गए किसी भी प्रश्न का उत्तर देने की अनुमति देता है।

सहभागिता डायग्राम

इंटरेक्शन आरेख वस्तुओं और उनके संबंधों की बातचीत को चित्रित करते हैं। इनमें उनके बीच पारित संदेश भी शामिल हैं। इंटरेक्शन आरेख दो प्रकार के होते हैं -

  • अनुक्रम आरेख
  • सहयोग आरेख

इंटरेक्शन आरेख का उपयोग मॉडलिंग के लिए किया जाता है -

  • अनुक्रम आरेखों का उपयोग करके समय-समय पर नियंत्रण प्रवाह।

  • सहयोग आरेखों का उपयोग करके संगठन का नियंत्रण प्रवाह।

अनुक्रम आरेख

अनुक्रम आरेख इंटरैक्शन आरेख हैं जो समय के अनुसार संदेशों के क्रम को चित्रित करते हैं।

Notations- ये आरेख दो-आयामी चार्ट के रूप में हैं। बातचीत शुरू करने वाली वस्तुओं को x- अक्ष पर रखा जाता है। ऊपर से नीचे तक बढ़ते समय के क्रम में ये वस्तुएं जो संदेश भेजती और प्राप्त करती हैं, उन्हें y- अक्ष के साथ रखा जाता है।

Example - ऑटोमेटेड ट्रेडिंग हाउस सिस्टम के लिए एक अनुक्रम आरेख निम्न आकृति में दिखाया गया है।

सहयोग आरेख

सहयोग आरेख बातचीत के आरेख हैं जो संदेश भेजने और प्राप्त करने वाली वस्तुओं की संरचना को चित्रित करते हैं।

Notations- इन आरेखों में, अंतर्क्रिया में भाग लेने वाली वस्तुओं को कोने का उपयोग करके दिखाया गया है। संदेशों को भेजने और प्राप्त करने के लिए वस्तुओं को जोड़ने वाले लिंक का उपयोग किया जाता है। संदेश को एक चिह्नित तीर के रूप में दिखाया गया है।

Example - ऑटोमेटेड ट्रेडिंग हाउस सिस्टम के लिए सहयोग आरेख नीचे दिए गए आंकड़े में चित्रित किया गया है।

राज्य-चार्ट आरेख

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

स्टेट-चार्ट डायग्राम में शामिल हैं -

  • स्टेट्स: सिंपल या कम्पोजिट
  • राज्यों के बीच संक्रमण
  • संक्रमण के कारण घटनाएँ
  • घटनाओं के कारण कार्य

स्टेट-चार्ट आरेख का उपयोग मॉडलिंग ऑब्जेक्ट्स के लिए किया जाता है जो प्रकृति में प्रतिक्रियाशील होते हैं।

Example

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

गतिविधि आरेख

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

गतिविधि आरेखों में शामिल हैं -

  • एक्टिविटी स्टेट्स और एक्शन स्टेट्स
  • Transitions
  • Objects

गतिविधि आरेख का उपयोग मॉडलिंग के लिए किया जाता है -

  • सिस्टम के साथ बातचीत करते हुए, अभिनेताओं द्वारा देखे गए वर्कफ़्लोज़।
  • फ़्लोचार्ट के उपयोग से संचालन या अभिकलन का विवरण।

Example

निम्नलिखित आंकड़ा स्वचालित ट्रेडिंग हाउस सिस्टम के एक हिस्से का एक गतिविधि आरेख दिखाता है।

विश्लेषण चरण के बाद, वैचारिक मॉडल को ऑब्जेक्ट-ओरिएंटेड डिज़ाइन (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

  • वर्णनात्मक के बजाय आरेख

ऑब्जेक्ट-ओरिएंटेड डिज़ाइन को लागू करने में आम तौर पर एक मानक ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग लैंग्वेज (OOPL) का उपयोग करना या ऑब्जेक्ट डिज़ाइन को डेटाबेस में मैप करना शामिल होता है। ज्यादातर मामलों में, इसमें दोनों शामिल हैं।

प्रोग्रामिंग भाषाओं का उपयोग करके कार्यान्वयन

आमतौर पर, ऑब्जेक्ट डिज़ाइन को कोड में बदलने का कार्य एक सीधी प्रक्रिया है। C ++, Java, Smalltalk, C # और Python जैसी कोई भी ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग लैंग्वेज में क्लासेस का प्रतिनिधित्व करने का प्रावधान शामिल है। इस अध्याय में, हम C ++ का उपयोग करते हुए अवधारणा का उदाहरण देते हैं।

निम्न आंकड़ा वर्ग सर्किल का प्रतिनिधित्व दर्शाता है C ++ का उपयोग करते हुए।

संघों को लागू करना

अधिकांश प्रोग्रामिंग भाषाएं संघों को सीधे लागू करने के लिए निर्माण प्रदान नहीं करती हैं। इसलिए संघों को लागू करने के कार्य पर काफी विचार करने की आवश्यकता है।

एसोसिएशन या तो यूनिडायरेक्शनल या बिडायरेक्शनल हो सकती हैं। इसके अलावा, प्रत्येक एसोसिएशन एक-से-एक, एक-से-कई, या कई-से-कई हो सकती है।

अप्रत्यक्ष संघ

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

  • Optional Associations- यहां, भाग लेने वाली वस्तुओं के बीच एक लिंक मौजूद हो सकता है या नहीं भी हो सकता है। उदाहरण के लिए, नीचे दिए गए आंकड़े में ग्राहक और चालू खाते के बीच संबंध में, ग्राहक के पास चालू खाता हो सकता है या नहीं भी हो सकता है।

कार्यान्वयन के लिए, चालू खाता की एक वस्तु ग्राहक में एक विशेषता के रूप में शामिल की गई है जो NULL हो सकती है। C ++ का उपयोग करके कार्यान्वयन -

class Customer {
   private:
   // attributes
   Current_Account c; //an object of Current_Account as attribute
   
   public:  

   Customer() {
      c = NULL; 
   } // assign c as NULL

   Current_Account getCurrAc() {
      return c;
   }
   
   void setCurrAc( Current_Account myacc) {
      c = myacc;
   }

   void removeAcc() {  
      c = NULL;
   } 
};
  • One–to–one Associations- यहां, एक वर्ग का एक उदाहरण संबंधित वर्ग के ठीक एक उदाहरण से संबंधित है। उदाहरण के लिए, विभाग और प्रबंधक में एक-से-एक एसोसिएशन है जैसा कि नीचे दिए गए आंकड़े में दिखाया गया है।

यह विभाग में शामिल करके कार्यान्वित किया जाता है, प्रबंधक की एक वस्तु जो NULL नहीं होनी चाहिए। C ++ का उपयोग करके कार्यान्वयन -

class Department {
   private:
   // attributes
   Manager mgr; //an object of Manager as attribute
   
   public:  
   Department (/*parameters*/, Manager m) { //m is not NULL   
      // assign parameters to variables
      mgr = m;
   } 

   Manager getMgr() {  
      return mgr;  
   }    
};
  • One–to–many Associations- यहां, एक वर्ग का एक उदाहरण संबंधित वर्ग के एक से अधिक उदाहरणों से संबंधित है। उदाहरण के लिए, निम्नलिखित आकृति में कर्मचारी और आश्रित के बीच संबंध पर विचार करें।

इसे कर्मचारी वर्ग के आश्रितों की सूची में शामिल किया गया है। C ++ STL सूची कंटेनर का उपयोग करके कार्यान्वयन -

class Employee {
   private:
   char * deptName;
   list <Dependent> dep; //a list of Dependents as attribute

   public:  
   void addDependent ( Dependent d) { 
      dep.push_back(d); 
   } // adds an employee to the department

   void removeDeoendent( Dependent d) { 
      int index = find ( d, dep );
      // find() function returns the index of d in list dep
      dep.erase(index);
   }               
};

द्वि-दिशात्मक संघ

द्वि-दिशात्मक संघ को लागू करने के लिए, दोनों दिशाओं में लिंक बनाए रखने की आवश्यकता होती है।

  • Optional or one–to–one Associations - परियोजना और परियोजना प्रबंधक के बीच के संबंध में विचार करें, एक-से-एक द्विदिश संघ, जैसा कि नीचे दिए गए आंकड़े में दिखाया गया है।

C ++ का उपयोग करके कार्यान्वयन -

Class Project {
   private:
   // attributes
   Project_Manager pmgr; 
   public:  
   void setManager ( Project_Manager pm);       
   Project_Manager changeManager();   
};

class Project_Manager {
   private:
   // attributes
   Project pj; 

   public:  
   void setProject(Project p);       
   Project removeProject();   
};
  • One–to–many Associations - डिपार्टमेंट और एम्प्लॉई के बीच एक-से-कई एसोसिएशन होने के संबंध पर विचार करें जैसा कि नीचे दिए गए आंकड़े में दिखाया गया है।

C ++ STL सूची कंटेनर का उपयोग करके कार्यान्वयन

class Department {
   private:
   char * deptName;
   list <Employee> emp; //a list of Employees as attribute

   public:  
   void addEmployee ( Employee e) { 
      emp.push_back(e); 
   } // adds an employee to the department

   void removeEmployee( Employee e) { 
      int index = find ( e, emp );
      // find function returns the index of e in list emp
      emp.erase(index);
   }               
};

class Employee {
   private:
   //attributes
   Department d;

   public:
   void addDept();
   void removeDept();
};

संघों को कक्षाओं के रूप में लागू करना

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

C ++ का उपयोग करके कार्यबल का कार्यान्वयन

class WorksOn {
   private:
   Employee e; 
   Project p;
   Hours h;
   char * date;

   public:
   // class methods
};

बाधाओं को लागू करना

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

Example

कर्मचारी वर्ग पर विचार करें जहां आयु एक विशेषता है जिसमें 18 से 60 की सीमा तक मान हो सकते हैं। निम्नलिखित C ++ कोड इसे शामिल करता है -

class Employee {
   private: char * name;
   int age;
   // other attributes

   public:
   Employee() {                 // default constructor   
      strcpy(name, "");
      age = 18;                // default value
   }
 
   class AgeError {};          // Exception class
   void changeAge( int a) {    // method that changes age

      if ( a < 18 || a > 60 )  // check for invalid condition
      throw AgeError();        // throw exception
      age = a;			
   }
};

राज्य चार्ट लागू करना

राज्य चार्ट आरेखों में राज्यों को लागू करने के लिए दो वैकल्पिक कार्यान्वयन रणनीतियों हैं।

कक्षा के भीतर गणना

इस दृष्टिकोण में, राज्यों को एक डेटा सदस्य (या डेटा सदस्यों के सेट) के विभिन्न मूल्यों द्वारा दर्शाया जाता है। मूल्यों को स्पष्ट रूप से वर्ग के भीतर एक गणना द्वारा परिभाषित किया गया है। संक्रमणों का प्रतिनिधित्व सदस्य कार्यों द्वारा किया जाता है जो संबंधित डेटा सदस्य के मूल्य को बदलते हैं।

एक सामान्यीकरण पदानुक्रम में कक्षाओं की व्यवस्था

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

डेटाबेस सिस्टम को ऑब्जेक्ट मैपिंग

वस्तुओं की दृढ़ता

ऑब्जेक्ट-ओरिएंटेड सिस्टम को विकसित करने का एक महत्वपूर्ण पहलू डेटा की दृढ़ता है। दृढ़ता के माध्यम से, वस्तुओं को उस कार्यक्रम की तुलना में अधिक लंबा जीवन मिला है जिसने इसे बनाया है। निरंतर डेटा को द्वितीयक संग्रहण माध्यम पर सहेजा जाता है, जहाँ से आवश्यकता पड़ने पर इसे पुनः लोड किया जा सकता है।

RDBMS का अवलोकन

एक डेटाबेस संबंधित डेटा का एक ऑर्डर किया गया संग्रह है।

एक डेटाबेस प्रबंधन प्रणाली (DBMS) सॉफ्टवेयर का एक संग्रह है जो डेटाबेस में डेटा को परिभाषित करने, बनाने, संग्रहीत करने, हेरफेर करने, पुनर्प्राप्त करने, साझा करने और निकालने की प्रक्रियाओं को सुविधाजनक बनाता है।

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

प्रत्येक पंक्ति को विशिष्ट रूप से न्यूनतम विशेषताओं के चुने हुए सेट द्वारा विशिष्ट रूप से पहचाना जाता है primary key

foreign key एक विशेषता है जो संबंधित तालिका की प्राथमिक कुंजी है।

RDBMS में टेबल्स के रूप में कक्षाओं का प्रतिनिधित्व करना

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

उदाहरण के लिए, सर्कल क्लास को तालिका में परिवर्तित किया जा सकता है जैसा कि नीचे दिए गए आंकड़े में दिखाया गया है।

Schema for Circle Table: CIRCLE(CID, X_COORD, Y_COORD, RADIUS, COLOR)
Creating a Table Circle using SQL command:
CREATE TABLE CIRCLE (   
   CID	VARCHAR2(4) PRIMARY KEY,
   X_COORD INTEGER NOT NULL,
   Y_COORD INTEGER NOT NULL,
   Z_COORD INTEGER NOT NULL,
   COLOR 
);

डेटाबेस टेबल्स के लिए मानचित्रण संघ

एक-से-एक संघ

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

SQL तालिका बनाने के लिए आदेश देता है

CREATE TABLE DEPARTMENT ( 
   DEPT_ID INTEGER PRIMARY KEY,
   DNAME VARCHAR2(30) NOT NULL,
   LOCATION VARCHAR2(20),
   EMPID INTEGER REFERENCES MANAGER 
);

CREATE TABLE MANAGER ( 
   EMPID INTEGER PRIMARY KEY,
   ENAME VARCHAR2(50) NOT NULL,
   ADDRESS VARCHAR2(70),
);

एक-से-कई संघ

1: एन एसोसिएशनों को लागू करने के लिए, एसोसिएशन के 1-साइड में टेबल की प्राथमिक कुंजी को एसोसिएशन के एन-साइड में टेबल की विदेशी कुंजी के रूप में सौंपा गया है। उदाहरण के लिए, विभाग और कर्मचारी के बीच संबंध पर विचार करें -

SQL तालिका बनाने के लिए आदेश देता है

CREATE TABLE DEPARTMENT ( 
   DEPT_ID INTEGER PRIMARY KEY,
   DNAME VARCHAR2(30) NOT NULL,
   LOCATION VARCHAR2(20),
);

CREATE TABLE EMPLOYEE ( 
   EMPID INTEGER PRIMARY KEY,
   ENAME VARCHAR2(50) NOT NULL,
   ADDRESS VARCHAR2(70),
   D_ID INTEGER REFERENCES DEPARTMENT
);

कई-से-कई संघ

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

Schema for Works_On Table - WORKS_ON (EMPID, PID, HOURS, START_DATE)

SQL command to create Works_On association - बनाएँ कार्य कार्यों

( 
   EMPID INTEGER,
   PID INTEGER, 
   HOURS INTEGER,
   START_DATE DATE,
   PRIMARY KEY (EMPID, PID),
   FOREIGN KEY (EMPID) REFERENCES EMPLOYEE,
   FOREIGN KEY (PID) REFERENCES PROJECT 
);

टेबल्स के लिए मैपिंग इनहेरिटेंस

विरासत का नक्शा बनाने के लिए, बेस टेबल (एस) की प्राथमिक कुंजी को प्राथमिक कुंजी के साथ-साथ व्युत्पन्न तालिका (ओं) में विदेशी कुंजी के रूप में सौंपा गया है।

Example

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

एक अन्य महत्वपूर्ण पहलू एक कार्यक्रम के उद्देश्य की फिटनेस है जो यह पता लगाता है कि क्या कार्यक्रम उस उद्देश्य को पूरा करता है जो इसके लिए उद्देश्य रखता है। फिटनेस सॉफ्टवेयर की गुणवत्ता को परिभाषित करता है।

परीक्षण ऑब्जेक्ट-ओरिएंटेड सिस्टम

सॉफ्टवेयर विकास के दौरान परीक्षण एक सतत गतिविधि है। ऑब्जेक्ट-ओरिएंटेड सिस्टम में, परीक्षण तीन स्तरों को सम्मिलित करता है, अर्थात्, यूनिट परीक्षण, सबसिस्टम परीक्षण, और सिस्टम परीक्षण।

इकाई का परीक्षण

यूनिट परीक्षण में, व्यक्तिगत कक्षाओं का परीक्षण किया जाता है। यह देखा जाता है कि क्या क्लास की विशेषताओं को डिज़ाइन के अनुसार लागू किया गया है या नहीं और क्या तरीके और इंटरफेस त्रुटि रहित हैं। इकाई परीक्षण संरचना को लागू करने वाले अनुप्रयोग इंजीनियर की जिम्मेदारी है।

सबसिस्टम परीक्षण

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

सिस्टम परीक्षण

सिस्टम परीक्षण में संपूर्ण रूप से सिस्टम का परीक्षण शामिल है और गुणवत्ता-आश्वासन टीम की जिम्मेदारी है। टीम अक्सर नई रिलीज़ को असेंबल करते समय सिस्टम टेस्ट को रिग्रेशन टेस्ट के रूप में उपयोग करती है।

ऑब्जेक्ट-ओरिएंटेड टेस्टिंग तकनीक

ग्रे बॉक्स परीक्षण

विभिन्न प्रकार के परीक्षण मामले जिन्हें ऑब्जेक्ट-ओरिएंटेड प्रोग्राम के परीक्षण के लिए डिज़ाइन किया जा सकता है, उन्हें ग्रे बॉक्स टेस्ट केस कहा जाता है। ग्रे बॉक्स परीक्षण के कुछ महत्वपूर्ण प्रकार हैं -

  • State model based testing - इसमें राज्य कवरेज, राज्य संक्रमण कवरेज और राज्य संक्रमण पथ कवरेज शामिल हैं।

  • Use case based testing - प्रत्येक उपयोग के मामले में प्रत्येक परिदृश्य का परीक्षण किया जाता है।

  • Class diagram based testing - प्रत्येक वर्ग, व्युत्पन्न वर्ग, संघों, और एकत्रीकरण का परीक्षण किया जाता है।

  • Sequence diagram based testing - अनुक्रम आरेख में संदेशों में विधियों का परीक्षण किया जाता है।

सबसिस्टम परीक्षण के लिए तकनीक

सबसिस्टम परीक्षण के दो मुख्य दृष्टिकोण हैं -

  • Thread based testing - एक सबसिस्टम में एकल उपयोग के मामले को महसूस करने के लिए आवश्यक सभी वर्गों को एकीकृत और परीक्षण किया जाता है।

  • Use based testing- पदानुक्रम के प्रत्येक स्तर पर मॉड्यूल के इंटरफेस और सेवाओं का परीक्षण किया जाता है। परीक्षण व्यक्तिगत वर्गों से शुरू होता है, जिसमें छोटे मॉड्यूल शामिल होते हैं, जिनमें धीरे-धीरे बड़े मॉड्यूल शामिल होते हैं, और अंत में सभी प्रमुख उपतंत्र।

सिस्टम परीक्षण की श्रेणियाँ

  • Alpha testing - यह सॉफ्टवेयर विकसित करने वाले संगठन के भीतर परीक्षण टीम द्वारा किया जाता है।

  • Beta testing - यह सह-संचालित ग्राहकों के चुनिंदा समूह द्वारा किया जाता है।

  • Acceptance testing - यह डिलिवरेबल्स स्वीकार करने से पहले ग्राहक द्वारा किया जाता है।

सॉफ्टवेयर क्वालिटी एश्योरेंस

सॉफ्टवेयर की गुणवत्ता

Schulmeyer और McManus ने सॉफ़्टवेयर गुणवत्ता को "कुल सॉफ़्टवेयर उत्पाद के उपयोग के लिए फिटनेस" के रूप में परिभाषित किया है। एक अच्छी गुणवत्ता वाला सॉफ्टवेयर वही करता है जो उसे करना चाहिए था और इसकी व्याख्या उपयोगकर्ता द्वारा निर्धारित आवश्यकता विनिर्देश की संतुष्टि के संदर्भ में की जाती है।

गुणवत्ता आश्वासन

सॉफ्टवेयर गुणवत्ता आश्वासन एक पद्धति है जो यह निर्धारित करती है कि सॉफ्टवेयर उत्पाद उपयोग के लिए किस हद तक फिट है। सॉफ्टवेयर की गुणवत्ता निर्धारित करने के लिए जो गतिविधियाँ शामिल हैं, वे हैं -

  • Auditing
  • मानकों और दिशानिर्देशों का विकास
  • रिपोर्ट का उत्पादन
  • गुणवत्ता प्रणाली की समीक्षा

गुणवत्ता कारक

  • Correctness - सुधार यह निर्धारित करता है कि क्या सॉफ्टवेयर आवश्यकताएं उचित रूप से पूरी की गई हैं।

  • Usability - उपयोगिता यह निर्धारित करती है कि सॉफ्टवेयर का उपयोग विभिन्न श्रेणियों के उपयोगकर्ताओं (शुरुआती, गैर-तकनीकी और विशेषज्ञों) द्वारा किया जा सकता है या नहीं।

  • Portability - पोर्टेबिलिटी यह निर्धारित करती है कि सॉफ्टवेयर विभिन्न हार्डवेयर उपकरणों के साथ विभिन्न प्लेटफार्मों में काम कर सकता है या नहीं।

  • Maintainability - स्थिरता, उस आसानी को निर्धारित करती है जिस पर त्रुटियों को ठीक किया जा सकता है और मॉड्यूल को अपडेट किया जा सकता है।

  • Reusability - पुन: प्रयोज्यता यह निर्धारित करती है कि क्या अन्य सॉफ्टवेयर उत्पादों को विकसित करने के लिए मॉड्यूल और कक्षाओं का पुन: उपयोग किया जा सकता है।

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

मेट्रिक्स को मोटे तौर पर तीन श्रेणियों में वर्गीकृत किया जा सकता है: प्रोजेक्ट मेट्रिक्स, उत्पाद मैट्रिक्स और प्रोसेस मेट्रिक्स।

प्रोजेक्ट मेट्रिक्स

प्रोजेक्ट मेट्रिक्स एक सॉफ्टवेयर प्रोजेक्ट मैनेजर को चालू प्रोजेक्ट की स्थिति और प्रदर्शन का आकलन करने में सक्षम बनाता है। ऑब्जेक्ट-ओरिएंटेड सॉफ़्टवेयर प्रोजेक्ट्स के लिए निम्न मीट्रिक उपयुक्त हैं -

  • परिदृश्य स्क्रिप्ट की संख्या
  • प्रमुख वर्गों की संख्या
  • सहायता वर्गों की संख्या
  • उपप्रणालियों की संख्या

उत्पाद मेट्रिक्स

उत्पाद मैट्रिक्स सॉफ्टवेयर उत्पाद की विशेषताओं को मापता है जिसे विकसित किया गया है। वस्तु-उन्मुख प्रणालियों के लिए उपयुक्त उत्पाद मैट्रिक्स हैं -

  • Methods per Class- यह एक वर्ग की जटिलता को निर्धारित करता है। यदि किसी वर्ग की सभी विधियों को समान रूप से जटिल माना जाता है, तो अधिक विधियों वाला वर्ग अधिक जटिल होता है और इस प्रकार त्रुटियों के प्रति अधिक संवेदनशील होता है।

  • Inheritance Structure- कई छोटे वंशानुक्रम अक्षांश वाले सिस्टम एकल बड़े वंशानुक्रम जाली वाले सिस्टम की तुलना में अधिक अच्छी तरह से संरचित हैं। एक अंगूठे के नियम के रूप में, एक विरासत के पेड़ में स्तरों की संख्या 7 (number 2) से अधिक नहीं होनी चाहिए और पेड़ संतुलित होना चाहिए।

  • Coupling and Cohesion - कम युग्मन और उच्च सामंजस्य वाले मॉड्यूल बेहतर डिज़ाइन किए जाते हैं, क्योंकि वे अधिक पुन: प्रयोज्य और रखरखाव की अनुमति देते हैं।

  • Response for a Class - यह उन तरीकों की दक्षता को मापता है जो कक्षा के उदाहरणों द्वारा बुलाए जाते हैं।

प्रक्रिया मेट्रिक्स

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

  • KLOC की संख्या (किलो लाइन्स ऑफ़ कोड)
  • दोष निवारण दक्षता
  • परीक्षण के दौरान औसतन विफलताओं का पता चला
  • KLOC प्रति अव्यक्त दोषों की संख्या