ऑब्जेक्ट-ओरिएंटेड प्रतिमान
ऑब्जेक्ट-ओरिएंटेड (OO) प्रतिमान एक नए प्रोग्रामिंग दृष्टिकोण की प्रारंभिक अवधारणा से अपना आकार ले लिया, जबकि डिजाइन और विश्लेषण के तरीकों में रुचि बहुत बाद में आई। OO विश्लेषण और डिजाइन प्रतिमान OO प्रोग्रामिंग भाषाओं को व्यापक रूप से अपनाने का तार्किक परिणाम है।
पहली वस्तु-उन्मुख भाषा थी Simula (वास्तविक प्रणालियों का अनुकरण) जो 1960 में नॉर्वेजियन कम्प्यूटिंग सेंटर के शोधकर्ताओं द्वारा विकसित किया गया था।
1970 में, Alan Kay और ज़ेरॉक्स PARC में उनके शोध समूह ने एक व्यक्तिगत कंप्यूटर बनाया Dynabook और पहला शुद्ध ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग लैंग्वेज (OOPL) - स्मॉलटॉक, डायनबूक की प्रोग्रामिंग के लिए।
उन्नीस सौ अस्सी के दशक में, Grady Boochऑब्जेक्ट ओरिएंटेड डिज़ाइन नामक एक पेपर प्रकाशित किया जो मुख्य रूप से प्रोग्रामिंग भाषा, एडा के लिए एक डिज़ाइन प्रस्तुत करता है। आगामी संस्करणों में, उन्होंने अपने विचारों को एक संपूर्ण ऑब्जेक्ट-ओरिएंटेड डिज़ाइन विधि में विस्तारित किया।
1990 में, Coad ऑब्जेक्ट-ओरिएंटेड विधियों में व्यवहार संबंधी विचारों को शामिल किया गया।
अन्य महत्वपूर्ण नवाचार ऑब्जेक्ट मॉडलिंग तकनीक (ओएमटी) थे James Rum Baugh और ऑब्जेक्ट ओरिएंटेड सॉफ्टवेयर इंजीनियरिंग (OOSE) द्वारा Ivar Jacobson।
OO प्रतिमान का परिचय
OO प्रतिमान किसी भी सॉफ्टवेयर के विकास के लिए एक महत्वपूर्ण पद्धति है। इस प्रतिमान का उपयोग करके अधिकांश वास्तुकला शैली या पैटर्न जैसे कि पाइप और फिल्टर, डेटा रिपॉजिटरी, और घटक-आधारित को लागू किया जा सकता है।
मूलभूत अवधारणाएं और वस्तु-उन्मुख प्रणालियों की शब्दावली -
वस्तु
एक वस्तु वस्तु-उन्मुख वातावरण में एक वास्तविक दुनिया तत्व है जिसमें एक भौतिक या एक वैचारिक अस्तित्व हो सकता है। प्रत्येक वस्तु है -
पहचान जो इसे सिस्टम में अन्य वस्तुओं से अलग करती है।
वह राज्य जो किसी वस्तु के गुणधर्मों के साथ-साथ उन गुणों के मूल्यों को भी निर्धारित करता है जो वस्तु रखती है।
व्यवहार जो किसी वस्तु द्वारा उसके राज्य में होने वाले परिवर्तनों के संदर्भ में बाहरी रूप से दिखाई देने वाली गतिविधियों का प्रतिनिधित्व करता है।
वस्तुओं को आवेदन की जरूरतों के अनुसार मॉडल किया जा सकता है। किसी वस्तु का भौतिक अस्तित्व हो सकता है, जैसे ग्राहक, कार, आदि; या एक अमूर्त वैचारिक अस्तित्व, जैसे एक परियोजना, एक प्रक्रिया, आदि।
कक्षा
एक वर्ग समान विशेषता वाले वस्तुओं के संग्रह का प्रतिनिधित्व करता है जो सामान्य व्यवहार प्रदर्शित करते हैं। यह उन वस्तुओं का खाका या विवरण देता है जिनसे इसे बनाया जा सकता है। किसी वर्ग के सदस्य के रूप में किसी वस्तु का निर्माण तात्कालिकता कहलाता है। इस प्रकार, एक वस्तु एक हैinstance एक कक्षा का।
एक वर्ग के घटक हैं -
उन वस्तुओं के लिए विशेषताओं का एक सेट जो कक्षा से तत्काल किया जाना है। आम तौर पर, एक वर्ग की विभिन्न वस्तुओं में विशेषताओं के मूल्यों में कुछ अंतर होता है। गुण अक्सर वर्ग डेटा के रूप में संदर्भित होते हैं।
संचालन का एक सेट जो कक्षा की वस्तुओं के व्यवहार को चित्रित करता है। संचालन को कार्यों या विधियों के रूप में भी संदर्भित किया जाता है।
Example
आइए एक साधारण वर्ग पर विचार करें, सर्कल, जो दो-आयामी अंतरिक्ष में ज्यामितीय आकृति सर्कल का प्रतिनिधित्व करता है। इस वर्ग की विशेषताओं को निम्नानुसार पहचाना जा सकता है -
- x- समन्वय, केंद्र के x- समन्वय को निरूपित करने के लिए
- y- समन्वय, केंद्र के y- समन्वय को निरूपित करने के लिए
- , वृत्त की त्रिज्या को दर्शाने के लिए
इसके कुछ कार्यों को निम्नानुसार परिभाषित किया जा सकता है -
- FindArea (), क्षेत्र की गणना करने के लिए एक विधि
- परिधि की गणना करने के लिए एक तरीका findCircumference ()
- स्केल (), त्रिज्या को बढ़ाने या घटाने की विधि
कैप्सूलीकरण
एनकैप्सुलेशन एक वर्ग के भीतर विशेषताओं और विधियों दोनों को एक साथ बांधने की प्रक्रिया है। एनकैप्सुलेशन के माध्यम से, एक वर्ग का आंतरिक विवरण बाहर से छिपाया जा सकता है। यह कक्षा के तत्वों को केवल कक्षा द्वारा प्रदान किए गए इंटरफ़ेस के माध्यम से बाहर से एक्सेस करने की अनुमति देता है।
बहुरूपता
बहुरूपता मूल रूप से एक ग्रीक शब्द है जिसका अर्थ है कई रूपों को लेने की क्षमता। ऑब्जेक्ट-ओरिएंटेड प्रतिमान में, बहुरूपता का तात्पर्य अलग-अलग तरीकों से संचालन से होता है, यह उन उदाहरणों पर निर्भर करता है, जिन पर वे काम कर रहे हैं। बहुरूपता विभिन्न आंतरिक संरचनाओं वाली वस्तुओं को एक सामान्य बाहरी इंटरफ़ेस की अनुमति देता है। विरासत को लागू करते समय बहुरूपता विशेष रूप से प्रभावी है।
Example
आइए हम दो वर्गों, सर्कल और स्क्वायर पर विचार करें, जिनमें से प्रत्येक में विधि findArea () है। यद्यपि कक्षाओं में विधियों का नाम और उद्देश्य समान हैं, आंतरिक कार्यान्वयन, अर्थात, प्रत्येक वर्ग के लिए एक क्षेत्र की गणना करने की प्रक्रिया अलग है। जब क्लास सर्कल की एक वस्तु अपनी खोज () विधि को आमंत्रित करती है, तो ऑपरेशन स्क्वायर वर्ग के फाइंडआरे () पद्धति के साथ किसी भी संघर्ष के बिना सर्कल के क्षेत्र का पता लगाता है।
Relationships
किसी प्रणाली का वर्णन करने के लिए, किसी प्रणाली के गतिशील (व्यवहारिक) और स्थैतिक (तार्किक) विनिर्देश दोनों को प्रदान किया जाना चाहिए। डायनामिक विनिर्देश वस्तुओं के बीच संबंधों का वर्णन करता है जैसे संदेश पास करना। और स्थिर विनिर्देश वर्गों के बीच संबंधों का वर्णन करते हैं, जैसे एकत्रीकरण, संघ और विरासत।
संदेश देना
किसी भी एप्लिकेशन को एक सामंजस्यपूर्ण तरीके से बातचीत करने वाली कई वस्तुओं की आवश्यकता होती है। सिस्टम में ऑब्जेक्ट संदेश पासिंग का उपयोग करके एक दूसरे के साथ संवाद कर सकते हैं। मान लीजिए कि एक सिस्टम में दो ऑब्जेक्ट हैं - obj1 और obj2। ऑब्जेक्ट obj1 ऑब्जेक्ट obj2 पर एक संदेश भेजता है, अगर obj1 obj2 अपने तरीकों में से एक को निष्पादित करना चाहता है।
रचना या एकत्रीकरण
एकत्रीकरण या रचना वर्गों के बीच एक संबंध है जिसके द्वारा एक वर्ग को अन्य वर्गों की वस्तुओं के संयोजन से बनाया जा सकता है। यह वस्तुओं को सीधे अन्य वर्गों के शरीर के भीतर रखने की अनुमति देता है। एकत्रीकरण को "भाग" के रूप में संदर्भित किया जाता है या "इसका" संबंध है, जिसमें संपूर्ण भागों से लेकर उसके हिस्सों तक नेविगेट करने की क्षमता है। एक समग्र वस्तु एक ऐसी वस्तु है जो एक या अधिक अन्य वस्तुओं से बनी होती है।
संगति
एसोसिएशन सामान्य संरचना और सामान्य व्यवहार वाले लिंक का एक समूह है। एसोसिएशन एक या एक से अधिक कक्षाओं की वस्तुओं के बीच के संबंध को दर्शाती है। एक लिंक को एसोसिएशन के एक उदाहरण के रूप में परिभाषित किया जा सकता है। एक संघ की डिग्री एक कनेक्शन में शामिल कक्षाओं की संख्या को दर्शाता है। डिग्री एकात्मक, बाइनरी या टर्नरी हो सकती है।
- एक समान संबंध एक ही वर्ग की वस्तुओं को जोड़ता है।
- एक द्विआधारी संबंध दो वर्गों की वस्तुओं को जोड़ता है।
- एक तिर्यक संबंध तीन या अधिक वर्गों की वस्तुओं को जोड़ता है।
विरासत
यह एक ऐसा तंत्र है जो अपनी क्षमताओं का विस्तार और परिशोधन करके नई कक्षाओं को मौजूदा कक्षाओं से बाहर करने की अनुमति देता है। मौजूदा वर्गों को आधार वर्ग / अभिभावक वर्ग / सुपर-क्लास कहा जाता है, और नई कक्षाओं को व्युत्पन्न वर्ग / बाल वर्ग / उपवर्ग कहा जाता है।
उपवर्ग सुपर क्लास (एस) की विशेषताओं और विधियों को इनहेरिट या प्राप्त कर सकते हैं बशर्ते कि सुपर क्लास ऐसा करने की अनुमति देता है। इसके अलावा, उपवर्ग अपनी विशेषताओं और विधियों को जोड़ सकता है और किसी भी सुपर-क्लास तरीकों को संशोधित कर सकता है। वंशानुक्रम एक "- संबंध" है।
Example
एक वर्ग स्तनपायी से, कई वर्गों को प्राप्त किया जा सकता है जैसे कि मानव, बिल्ली, कुत्ता, गाय, आदि मनुष्य, बिल्ली, कुत्ते और गाय सभी स्तनधारियों की विशिष्ट विशेषताएं हैं। इसके अलावा, प्रत्येक की अपनी विशिष्ट विशेषताएं हैं। यह कहा जा सकता है कि एक गाय "एक" स्तनपायी है।
ऊ विश्लेषण
सॉफ्टवेयर विकास के वस्तु-उन्मुख विश्लेषण चरण में, सिस्टम आवश्यकताओं को निर्धारित किया जाता है, कक्षाओं की पहचान की जाती है, और कक्षाओं के बीच संबंधों को स्वीकार किया जाता है। OO विश्लेषण का उद्देश्य अनुप्रयोग डोमेन और सिस्टम की विशिष्ट आवश्यकताओं को समझना है। इस चरण का परिणाम आवश्यकता विनिर्देश और तार्किक संरचना का प्रारंभिक विश्लेषण और एक प्रणाली की व्यवहार्यता है।
ऑब्जेक्ट-ओरिएंटेड विश्लेषण के लिए एक-दूसरे के साथ संयोजन में उपयोग की जाने वाली तीन विश्लेषण तकनीक ऑब्जेक्ट मॉडलिंग, डायनेमिक मॉडलिंग और फ़ंक्शनल मॉडलिंग हैं।
ऑब्जेक्ट मॉडलिंग
ऑब्जेक्ट मॉडलिंग वस्तुओं के संदर्भ में सॉफ्टवेयर सिस्टम की स्थिर संरचना को विकसित करता है। यह वस्तुओं की पहचान करता है, उन वर्गों को जिनमें वस्तुओं को समूहित किया जा सकता है और वस्तुओं के बीच संबंध। यह उन मुख्य विशेषताओं और कार्यों की भी पहचान करता है जो प्रत्येक वर्ग की विशेषता रखते हैं।
ऑब्जेक्ट मॉडलिंग की प्रक्रिया को निम्नलिखित चरणों में देखा जा सकता है -
- वस्तुओं और समूह को कक्षाओं में पहचानें
- वर्गों के बीच संबंधों को पहचानें
- उपयोगकर्ता ऑब्जेक्ट मॉडल आरेख बनाएं
- उपयोगकर्ता ऑब्जेक्ट विशेषताओं को परिभाषित करें
- उन कार्यों को परिभाषित करें जिन्हें कक्षाओं पर किया जाना चाहिए
डायनामिक मॉडलिंग
सिस्टम के स्थिर व्यवहार का विश्लेषण करने के बाद, समय और बाहरी परिवर्तनों के संबंध में इसके व्यवहार की जांच की जानी चाहिए। यह गतिशील मॉडलिंग का उद्देश्य है।
डायनामिक मॉडलिंग को "किसी व्यक्ति द्वारा घटनाओं के प्रति प्रतिक्रिया देने के तरीके, या तो बाहरी वस्तुओं द्वारा ट्रिगर की गई आंतरिक घटनाओं, या बाहरी दुनिया द्वारा ट्रिगर की गई बाहरी घटनाओं के रूप में वर्णन करने का एक तरीका" के रूप में परिभाषित किया जा सकता है।
गतिशील मॉडलिंग की प्रक्रिया को निम्नलिखित चरणों में देखा जा सकता है -
- प्रत्येक वस्तु की अवस्थाओं को पहचानें
- घटनाओं को पहचानें और कार्यों की प्रयोज्यता का विश्लेषण करें
- एक गतिशील मॉडल आरेख का निर्माण, जिसमें राज्य संक्रमण आरेख शामिल हैं
- प्रत्येक राज्य को वस्तु विशेषताओं के संदर्भ में व्यक्त करें
- तैयार किए गए राज्य-संक्रमण आरेखों को मान्य करें
कार्यात्मक मॉडलिंग
कार्यात्मक मॉडलिंग वस्तु-उन्मुख विश्लेषण का अंतिम घटक है। कार्यात्मक मॉडल उन प्रक्रियाओं को दिखाता है जो किसी ऑब्जेक्ट के भीतर किए जाते हैं और डेटा कैसे बदलता है, क्योंकि यह विधियों के बीच चलता है। यह ऑब्जेक्ट मॉडलिंग के संचालन और गतिशील मॉडलिंग के कार्यों का अर्थ निर्दिष्ट करता है। कार्यात्मक मॉडल पारंपरिक संरचित विश्लेषण के डेटा प्रवाह आरेख से मेल खाती है।
कार्यात्मक मॉडलिंग की प्रक्रिया को निम्नलिखित चरणों में देखा जा सकता है -
- सभी इनपुट और आउटपुट को पहचानें
- कार्यात्मक निर्भरता दिखाने वाले डेटा प्रवाह आरेख का निर्माण करते हैं
- प्रत्येक फ़ंक्शन का उद्देश्य बताएं
- बाधाओं की पहचान करें
- अनुकूलन मानदंड निर्दिष्ट करें
ऑब्जेक्ट-ओरिएंटेड डिज़ाइन
विश्लेषण चरण के बाद, वैचारिक मॉडल को ऑब्जेक्ट-ओरिएंटेड डिज़ाइन (OOD) का उपयोग करके ऑब्जेक्ट-ओरिएंटेड मॉडल में और विकसित किया जाता है। OOD में, विश्लेषण मॉडल में प्रौद्योगिकी-स्वतंत्र अवधारणाओं को कक्षाएं लागू करने पर मैप किया जाता है, बाधाओं की पहचान की जाती है, और इंटरफेस डिज़ाइन किए जाते हैं, जिसके परिणामस्वरूप समाधान डोमेन के लिए एक मॉडल होता है। OO डिजाइन का मुख्य उद्देश्य एक सिस्टम की संरचनात्मक वास्तुकला को विकसित करना है।
ऑब्जेक्ट-ओरिएंटेड डिज़ाइन के चरणों की पहचान इस प्रकार की जा सकती है -
- प्रणाली के संदर्भ को परिभाषित करना
- सिस्टम आर्किटेक्चर को डिज़ाइन करना
- प्रणाली में वस्तुओं की पहचान
- डिजाइन मॉडल का निर्माण
- ऑब्जेक्ट इंटरफेस की विशिष्टता
OO Design को दो चरणों में विभाजित किया जा सकता है - अवधारणात्मक डिज़ाइन और विस्तृत डिज़ाइन।
Conceptual design
इस चरण में, सभी वर्गों की पहचान की जाती है जो सिस्टम के निर्माण के लिए आवश्यक हैं। इसके अलावा, प्रत्येक वर्ग को विशिष्ट जिम्मेदारियां सौंपी जाती हैं। वर्ग आरेख का उपयोग कक्षाओं के बीच संबंधों को स्पष्ट करने के लिए किया जाता है, और घटनाओं के प्रवाह को दिखाने के लिए इंटरैक्शन आरेख का उपयोग किया जाता है। इसे के रूप में भी जाना जाता हैhigh-level design।
Detailed design
इस चरण में, विशेषताओं और संचालन को प्रत्येक वर्ग को उनके इंटरैक्शन आरेख के आधार पर सौंपा गया है। डिजाइन के आगे के विवरण का वर्णन करने के लिए राज्य मशीन आरेख विकसित किया गया है। इसे के रूप में भी जाना जाता हैlow-level design।
डिज़ाइन सिद्धांत
निम्नलिखित प्रमुख डिजाइन सिद्धांत हैं -
Principle of Decoupling
अत्यधिक अन्योन्याश्रित वर्गों के एक सेट के साथ एक प्रणाली को बनाए रखना मुश्किल है, क्योंकि एक वर्ग में संशोधन के परिणामस्वरूप अन्य कक्षाओं के कैस्केडिंग अपडेट हो सकते हैं। एक OO डिजाइन में, तंग युग्मन को नई कक्षाओं या वंशानुक्रम को शुरू करके समाप्त किया जा सकता है।
Ensuring Cohesion
एक एकजुट वर्ग बारीकी से संबंधित कार्यों का एक सेट करता है। सामंजस्य की कमी का मतलब है - एक वर्ग असंबंधित कार्य करता है, हालांकि यह पूरे सिस्टम के संचालन को प्रभावित नहीं करता है। यह सॉफ्टवेयर की संपूर्ण संरचना को प्रबंधित करने, विस्तार करने, बनाए रखने और बदलने के लिए कठिन बनाता है।
Open-closed Principle
इस सिद्धांत के अनुसार, एक प्रणाली को नई आवश्यकताओं को पूरा करने में सक्षम होना चाहिए। मौजूदा कार्यान्वयन और सिस्टम के कोड को सिस्टम विस्तार के परिणामस्वरूप संशोधित नहीं किया जाना चाहिए। इसके अलावा, खुले-बंद सिद्धांत में निम्नलिखित दिशानिर्देशों का पालन करना होगा -
प्रत्येक ठोस वर्ग के लिए, अलग-अलग इंटरफ़ेस और कार्यान्वयन बनाए रखना होगा।
एक बहुआयामी वातावरण में, विशेषताओं को निजी रखें।
वैश्विक चर और वर्ग चर का उपयोग कम से कम करें।