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

From Vigyanwiki
No edit summary
 
(8 intermediate revisions by 4 users not shown)
Line 1: Line 1:
{{short description|Programming paradigm based on the concept of objects}}
{{short description|Programming paradigm based on the concept of objects}}
''"वस्तु-उन्मुख" यहां पुनर्निर्देश करता है। वस्तु-उन्मुख के अन्य अर्थों के लिए, वस्तु-उन्मुखीकरण देखें।''{{Programming paradigms}}
'''''वस्तु-उन्मुख प्रोग्रामिंग (ओओपी)''''' वस्तु (ऑब्जेक्ट)" की अवधारणा पर आधारित एक प्रोग्रामिंग पैराडिग्म है, जिसमें डेटा और कोड हो सकते हैं। डेटा क्षेत्र के रूप में होता है (प्रायः विशेषता या गुण के रूप में जाना जाता है), और कोड प्रक्रियाओं के रूप में होता है (प्रायः विधियों के रूप में जाना जाता है)।
वस्तु-उन्मुख प्रोग्रामिंग (ओओपी) वस्तु (ऑब्जेक्ट)" की अवधारणा पर आधारित एक प्रोग्रामिंग प्रतिमान है, जिसमें डेटा और कोड हो सकते हैं। डेटा क्षेत्र के रूप में होता है (प्रायः विशेषता या गुण के रूप में जाना जाता है), और कोड प्रक्रियाओं के रूप में होता है (प्रायः विधियों के रूप में जाना जाता है)।


वस्तुओं की एक सामान्य विशेषता यह है कि प्रक्रियाएँ (या विधियाँ) उनसे जुड़ी होती हैं और वस्तु के डेटा क्षेत्रों तक पहुँच और संशोधित कर सकती हैं। वस्तु-उन्मुख प्रोग्रामिंग के इस ब्रांड में सामान्य रूप से एक विशेष नाम होता है जैसे {{code|this|C++}} (कंप्यूटर प्रोग्रामिंग) या {{code|self|swift}} वर्तमान वस्तु को संदर्भित करने के लिए उपयोग किया जाता है। वस्तु-उन्मुख प्रोग्रामिंग में, कंप्यूटर प्रोग्राम को उन वस्तुओं से बनाकर डिज़ाइन किया जाता है जो एक दूसरे के साथ परस्पर क्रिया करते हैं।<ref>{{Cite journal
वस्तुओं की एक सामान्य विशेषता यह है कि प्रक्रियाएँ (या विधियाँ) उनसे जुड़ी होती हैं और वस्तु के डेटा क्षेत्रों तक पहुँच और संशोधित कर सकती हैं। वस्तु-उन्मुख प्रोग्रामिंग के इस ब्रांड में सामान्य रूप से एक विशेष नाम होता है जैसे {{code|this|C++}} (कंप्यूटर प्रोग्रामिंग) या {{code|self|swift}} वर्तमान वस्तु को संदर्भित करने के लिए उपयोग किया जाता है। वस्तु-उन्मुख प्रोग्रामिंग में, कंप्यूटर प्रोग्राम को उन वस्तुओं से बनाकर डिज़ाइन किया जाता है जो एक दूसरे के साथ परस्पर क्रिया करते हैं।<ref>{{Cite journal
Line 8: Line 7:
   | title = Object-Oriented Simulation of systems with sophisticated control
   | title = Object-Oriented Simulation of systems with sophisticated control
   | publisher = International Journal of General Systems
   | publisher = International Journal of General Systems
   | year = 2011 | pages = 313–343}}</ref><ref>{{Cite book|last1=Lewis|first1=John|last2=Loftus|first2= William|title=Java Software Solutions Foundations of Programming Design 6th ed|publisher=Pearson Education Inc.|year=2008|isbn=978-0-321-53205-3}}, section 1.6 "Object-Oriented Programming"</ref> वस्तु-उन्मुख प्रोग्रामिंग भाषाएँ विविध हैं, लेकिन सबसे लोकप्रिय [[कक्षा आधारित प्रोग्रामिंग|क्लास आधारित प्रोग्रामिंग]] जिसका अर्थ है कि ऑब्जेक्ट क्लास (कंप्यूटर विज्ञान) के [[उदाहरण (कंप्यूटर विज्ञान)]] हैं, जो उनके [[डेटा प्रकार]] को भी निर्धारित करते हैं।
   | year = 2011 | pages = 313–343}}</ref><ref>{{Cite book|last1=Lewis|first1=John|last2=Loftus|first2= William|title=Java Software Solutions Foundations of Programming Design 6th ed|publisher=Pearson Education Inc.|year=2008|isbn=978-0-321-53205-3}}, section 1.6 "Object-Oriented Programming"</ref> वस्तु-उन्मुख प्रोग्रामिंग भाषाएँ विविध हैं, लेकिन सबसे लोकप्रिय [[कक्षा आधारित प्रोग्रामिंग|क्लास आधारित प्रोग्रामिंग]] जिसका अर्थ है कि ऑब्जेक्ट क्लास (कंप्यूटर विज्ञान) के [[उदाहरण (कंप्यूटर विज्ञान)]] हैं, जो उनके [[डेटा प्रकार]] को भी निर्धारित करते हैं।


सबसे व्यापक रूप से उपयोग की जाने वाली प्रोग्रामिंग भाषाओं में से कई (जैसे [[सी ++|C ++]], जावा, पायथन, आदि) [[बहु-प्रतिमान प्रोग्रामिंग भाषा]] हैं।और वे वस्तु-उन्मुख प्रोग्रामिंग को अधिक या कम सीमा के लिए सामान्य रूप से अनिवार्य, [[प्रक्रियात्मक प्रोग्रामिंग]] के संयोजन में समर्थन करते हैं।  
सबसे व्यापक रूप से उपयोग की जाने वाली प्रोग्रामिंग भाषाओं में से कई (जैसे [[सी ++|C ++]], जावा, पायथन, आदि) [[बहु-प्रतिमान प्रोग्रामिंग भाषा|बहु-पैराडिग्म प्रोग्रामिंग भाषा]] हैं। और वे वस्तु-उन्मुख प्रोग्रामिंग को अधिक या कम सीमा के लिए सामान्य रूप से अनिवार्य, [[प्रक्रियात्मक प्रोग्रामिंग]] के संयोजन में समर्थन करते हैं।  


महत्वपूर्ण वस्तु-उन्मुख भाषाओं में [[एडा (प्रोग्रामिंग भाषा)|एडीए (प्रोग्रामिंग भाषा)]], [[ActionScript|एक्शनस्क्रिप्ट]], C++, [[सामान्य लिस्प]], C #, [[डार्ट (प्रोग्रामिंग भाषा)]], [[एफिल (प्रोग्रामिंग भाषा)]], [[फोरट्रान|फोरट्रान 2003, हैक्स]], [[जावा (प्रोग्रामिंग भाषा)]] , [[जावास्क्रिप्ट]], [[कोटलिन (प्रोग्रामिंग भाषा)]], [[लोगो (प्रोग्रामिंग भाषा)]], [[MATLAB|मैटलैब]], [[उद्देश्य सी|ऑब्जेक्टिव-C]], [[वस्तु पास्कल|ऑब्जेक्ट पास्कल]], [[पर्ल]], [[पीएचपी]], पायथन (प्रोग्रामिंग भाषा), [[आर (प्रोग्रामिंग भाषा)]], [[राकू (प्रोग्रामिंग भाषा)]], [[रूबी (प्रोग्रामिंग भाषा)]] ), [[स्काला (प्रोग्रामिंग भाषा)]], [[SIMSCRIPT|सिमस्क्रिप्ट]], [[शुरुआत|सिमुला]], स्मॉलटॉक, [[स्विफ्ट (प्रोग्रामिंग भाषा)]], [[वाला (प्रोग्रामिंग लैंग्वेज)|वाला (प्रोग्रामिंग भाषा)]] और विजुअल बेसिक.नेट सम्मिलित हैं।
महत्वपूर्ण वस्तु-उन्मुख भाषाओं में [[एडा (प्रोग्रामिंग भाषा)|एडीए (प्रोग्रामिंग भाषा)]], [[ActionScript|एक्शनस्क्रिप्ट]], C++, [[सामान्य लिस्प]], C #, [[डार्ट (प्रोग्रामिंग भाषा)]], [[एफिल (प्रोग्रामिंग भाषा)]], [[फोरट्रान|फोरट्रान 2003, हैक्स]], [[जावा (प्रोग्रामिंग भाषा)]], [[जावास्क्रिप्ट]], [[कोटलिन (प्रोग्रामिंग भाषा)]], [[लोगो (प्रोग्रामिंग भाषा)]], [[MATLAB|मैटलैब]], [[उद्देश्य सी|ऑब्जेक्टिव-C]], [[वस्तु पास्कल|ऑब्जेक्ट पास्कल]], [[पर्ल]], [[पीएचपी]], पायथन (प्रोग्रामिंग भाषा), [[आर (प्रोग्रामिंग भाषा)]], [[राकू (प्रोग्रामिंग भाषा)]], [[रूबी (प्रोग्रामिंग भाषा)]] ), [[स्काला (प्रोग्रामिंग भाषा)]], [[SIMSCRIPT|सिमस्क्रिप्ट]], [[शुरुआत|सिमुला]], स्मॉलटॉक, [[स्विफ्ट (प्रोग्रामिंग भाषा)]], [[वाला (प्रोग्रामिंग लैंग्वेज)|वाला (प्रोग्रामिंग भाषा)]] और विजुअल बेसिक.नेट सम्मिलित हैं।


== इतिहास ==
== इतिहास ==
[[File:oop-uml-class-example.png|frame|right|किसी क्लास के लिए यूएमएल संकेतन। इस बटन क्लास में डेटा और फ़ंक्शंस के लिए वेरिएबल्स (चर) हैं। इनहेरिटेंस के माध्यम से एक सबक्लास को बटन क्लास के उपसमुच्चय के रूप में बनाया जा सकता है।ऑब्जेक्ट एक क्लास के उदाहरण हैं।]]1950 के दशक के अंत और 1960 के दशक की प्रारंभ में वस्तु-उन्मुख प्रोग्रामिंग के आधुनिक अर्थों में वस्तुओं को प्रेरक करने वाली और उन्मुख शब्दावली ने मेसाचुसेट्स प्रौद्योगिक संस्थान में अपनी पहली उपस्थिति दर्ज की। [[कृत्रिम होशियारी|कृत्रिम बुद्धि समूह]] के वातावरण में, 1960 की प्रारंभ में, "वस्तु" गुणों (विशेषताओं) के [[साथ]] पहचानी गई वस्तुओं ([[लिस्प (प्रोग्रामिंग भाषा)|एलआईएसपी (प्रोग्रामिंग भाषा)]] परमाणुओं) को संदर्भित कर सकती थी;<ref>{{Cite journal
[[File:oop-uml-class-example.png|frame|right|किसी क्लास के लिए यूएमएल संकेतन। इस बटन क्लास में डेटा और फ़ंक्शंस के लिए वेरिएबल्स हैं। इनहेरिटेंस के माध्यम से एक सबक्लास को बटन क्लास के उपसमुच्चय के रूप में बनाया जा सकता है।ऑब्जेक्ट एक क्लास के उदाहरण हैं।]]1950 के दशक के अंत और 1960 के दशक की प्रारंभ में वस्तु-उन्मुख प्रोग्रामिंग के आधुनिक अर्थों में वस्तुओं को प्रेरक करने वाली और उन्मुख शब्दावली ने मेसाचुसेट्स प्रौद्योगिक संस्थान में अपनी पहली उपस्थिति दर्ज की। [[कृत्रिम होशियारी|कृत्रिम बुद्धि समूह]] के वातावरण में, 1960 की प्रारंभ में, "वस्तु" गुणों (विशेषताओं) के [[साथ]] पहचानी गई वस्तुओं ([[लिस्प (प्रोग्रामिंग भाषा)|एलआईएसपी (प्रोग्रामिंग भाषा)]] परमाणुओं) को संदर्भित कर सकती थी;<ref>{{Cite journal
  |last1=McCarthy
  |last1=McCarthy
  |first1=J.
  |first1=J.
Line 79: Line 78:
  |width  = 50%
  |width  = 50%
}}
}}
एक अन्य प्रारंभिक एमआईटी उदाहरण 1960-1961 में इवान सदरलैंड द्वारा रचित स्केचपैड था; स्केचपैड के बारे में अपने शोध प्रबंध पर आधारित 1963 की तकनीकी रिपोर्ट की शब्दावली में, सदरलैंड ने "ऑब्जेक्ट" और "इंस्टेंस" ("विशेषज्ञ" या "परिभाषा" द्वारा आच्छादित की गई वर्ग अवधारणा के साथ) की धारणाओं को परिभाषित किया, हालांकि यह ग्राफिकल पारस्परिक क्रिया के लिए विशेष है।<ref>{{Cite web|url=http://handle.dtic.mil/100.2/AD404549|archive-url=https://web.archive.org/web/20130408133119/http://handle.dtic.mil/100.2/AD404549|url-status=dead|archive-date=8 April 2013|title=Sketchpad: A Man-Machine Graphical Communication System|author=Sutherland, I. E.|date=30 January 1963|publisher=Technical Report No. 296, Lincoln Laboratory, Massachusetts Institute of Technology via Defense Technical Information Center (stinet.dtic.mil)|access-date=17 July 2019}}<!-- Seems to be fixed  --></ref>इसके अतिरिक्त, एक मेसाचुसेट्स प्रौद्योगिक संस्थान एल्गोरिथम भाषा संस्करण, एईडी-0, ने डेटा संरचनाओं ("प्लेक्स", उस प्राकृत भाषा में) और प्रक्रियाओं के बीच एक सीधा लिंक स्थापित किया, जो बाद में संदेशों, विधियों और मेम्बर फंक्शन को पूर्वनिर्धारित करता है।<ref name=simuladev>
एक अन्य प्रारंभिक एमआईटी उदाहरण 1960-1961 में इवान सदरलैंड द्वारा रचित स्केचपैड था; स्केचपैड के बारे में अपने शोध प्रबंध पर आधारित 1963 की तकनीकी रिपोर्ट की शब्दावली में, सदरलैंड ने "ऑब्जेक्ट" और "इंस्टेंस" ("विशेषज्ञ" या "परिभाषा" द्वारा आच्छादित की गई क्लास अवधारणा के साथ) की धारणाओं को परिभाषित किया, हालांकि यह ग्राफिकल पारस्परिक क्रिया के लिए विशेष है।<ref>{{Cite web|url=http://handle.dtic.mil/100.2/AD404549|archive-url=https://web.archive.org/web/20130408133119/http://handle.dtic.mil/100.2/AD404549|url-status=dead|archive-date=8 April 2013|title=Sketchpad: A Man-Machine Graphical Communication System|author=Sutherland, I. E.|date=30 January 1963|publisher=Technical Report No. 296, Lincoln Laboratory, Massachusetts Institute of Technology via Defense Technical Information Center (stinet.dtic.mil)|access-date=17 July 2019}}<!-- Seems to be fixed  --></ref>इसके अतिरिक्त, एक मेसाचुसेट्स प्रौद्योगिक संस्थान एल्गोरिथम भाषा संस्करण, एईडी-0, ने डेटा संरचनाओं ("प्लेक्स", उस प्राकृत भाषा में) और प्रक्रियाओं के बीच एक सीधा लिंक स्थापित किया, जो बाद में संदेशों, विधियों और मेम्बर फंक्शन को पूर्वनिर्धारित करता है।<ref name=simuladev>
  The Development of the Simula Languages,
  The Development of the Simula Languages,
  [[Kristen Nygaard]], [[Ole-Johan Dahl]],
  [[Kristen Nygaard]], [[Ole-Johan Dahl]],
Line 100: Line 99:
1970 के दशक में, स्मॉलटाक ने लिस्प (प्रोग्रामिंग भाषा) समुदाय को ऑब्जेक्ट-आधारित तकनीकों को सम्मिलित करने के लिए प्रभावित किया, जिन्हें [[लिस्प मशीन]] के माध्यम से विकासक के लिए प्रस्तुत किया गया था। लिस्प के विभिन्न एक्सटेंशन के साथ प्रयोग (जैसे लूप्स और [[जायके (प्रोग्रामिंग भाषा)]] [[एकाधिक वंशानुक्रम|एकाधिक इनहेरिटेंस]] और [[मिश्रण|मिक्सिन्स]] को प्रस्तुत करते हुए) अंततः सामान्य [[कॉमन लिस्प ऑब्जेक्ट सिस्टम|लिस्प ऑब्जेक्ट प्रणाली]] का नेतृत्व किया, जो कार्यात्मक प्रोग्रामिंग और वस्तु-उन्मुख प्रोग्रामिंग को एकीकृत करता है और [[मेटा-ऑब्जेक्ट प्रोटोकॉल]] के माध्यम से विस्तार की स्वीकृति देता है। 1980 के दशक में, प्रोसेसर संरचना को डिजाइन करने के कुछ प्रयास हुए जिनमें मेमोरी में वस्तुओं के लिए हार्डवेयर समर्थन सम्मिलित था लेकिन ये सफल नहीं रहे। उदाहरणों में [[Intel iAPX 432|इंटेल उन्नत प्रदर्शन संरचना 432]] और लिन स्मार्ट रेकुर्सिव सम्मिलित हैं।
1970 के दशक में, स्मॉलटाक ने लिस्प (प्रोग्रामिंग भाषा) समुदाय को ऑब्जेक्ट-आधारित तकनीकों को सम्मिलित करने के लिए प्रभावित किया, जिन्हें [[लिस्प मशीन]] के माध्यम से विकासक के लिए प्रस्तुत किया गया था। लिस्प के विभिन्न एक्सटेंशन के साथ प्रयोग (जैसे लूप्स और [[जायके (प्रोग्रामिंग भाषा)]] [[एकाधिक वंशानुक्रम|एकाधिक इनहेरिटेंस]] और [[मिश्रण|मिक्सिन्स]] को प्रस्तुत करते हुए) अंततः सामान्य [[कॉमन लिस्प ऑब्जेक्ट सिस्टम|लिस्प ऑब्जेक्ट प्रणाली]] का नेतृत्व किया, जो कार्यात्मक प्रोग्रामिंग और वस्तु-उन्मुख प्रोग्रामिंग को एकीकृत करता है और [[मेटा-ऑब्जेक्ट प्रोटोकॉल]] के माध्यम से विस्तार की स्वीकृति देता है। 1980 के दशक में, प्रोसेसर संरचना को डिजाइन करने के कुछ प्रयास हुए जिनमें मेमोरी में वस्तुओं के लिए हार्डवेयर समर्थन सम्मिलित था लेकिन ये सफल नहीं रहे। उदाहरणों में [[Intel iAPX 432|इंटेल उन्नत प्रदर्शन संरचना 432]] और लिन स्मार्ट रेकुर्सिव सम्मिलित हैं।


1981 में, गोल्डबर्ग ने [[बाइट पत्रिका]] के अगस्त अंक को संपादित किया, जिसमें व्यापक दर्शकों के लिए स्मॉलटाक और वस्तु-उन्मुख प्रोग्रामिंग की प्रारंभ की गई। 1986 में, कंप्यूटिंग मशीनरी के लिए संघ ने वस्तु-उन्मुख प्रोग्रामिंग, सिस्टम्स, भाषाये और एप्लिकेशन (ओओपीएसएलए) पर पहला सम्मेलन आयोजित किया, जिसमें अप्रत्याशित रूप से 1,000 लोगों ने भाग लिया। 1980 के दशक के मध्य में ब्रैड कॉक्स द्वारा ऑब्जेक्टिव-C विकसित किया गया था, जिन्होंने आईटीटी इंक में स्मॉलटाक का इस्तेमाल किया था, और बजेर्न स्ट्रॉस्ट्रुप, जिन्होंने अपनी पीएचडी थीसिस के लिए सिमुला का इस्तेमाल किया था, अंततः वस्तु-उन्मुख C ++ बनाने के लिए गए।<ref name="Bertrand Meyer 2009 329" /> 1985 में, [[बर्ट्रेंड मेयर]] ने एफिल (प्रोग्रामिंग भाषा) का पहला डिज़ाइन भी तैयार किया। सॉफ्टवेयर गुणवत्ता पर केंद्रित, एफिल विशुद्ध रूप से वस्तु-उन्मुख प्रोग्रामिंग भाषा है और संपूर्ण सॉफ्टवेयर जीवनचक्र का समर्थन करने वाला एक संकेत है। मेयर ने [[वस्तु-उन्मुख सॉफ्टवेयर निर्माण]] में सॉफ्टवेयर इंजीनियरिंग और कंप्यूटर विज्ञान से कुछ प्रमुख विचारों के आधार पर एफिल सॉफ्टवेयर विकास पद्धति का वर्णन किया। एफिल की गुणवत्ता पर ध्यान केंद्रित करने के लिए अनिवार्य है मेयर की विश्वसनीयता तंत्र, [[अनुबंध द्वारा डिजाइन]], जो विधि और भाषा दोनों का एक अभिन्न भाग है।
1981 में, गोल्डबर्ग ने [[बाइट पत्रिका]] के अगस्त अंक को संपादित किया, जिसमें व्यापक दर्शकों के लिए स्मॉलटाक और वस्तु-उन्मुख प्रोग्रामिंग की प्रारंभ की गई। 1986 में, कंप्यूटिंग मशीनरी के लिए संघ ने वस्तु-उन्मुख प्रोग्रामिंग, सिस्टम्स, भाषाये और एप्लिकेशन (ओओपीएसएलए) पर पहला सम्मेलन आयोजित किया, जिसमें अप्रत्याशित रूप से 1,000 लोगों ने भाग लिया। 1980 के दशक के मध्य में ब्रैड कॉक्स द्वारा ऑब्जेक्टिव-C विकसित किया गया था, जिन्होंने आईटीटी इंक में स्मॉलटाक का उपयोग किया था, और बजेर्न स्ट्रॉस्ट्रुप, जिन्होंने अपनी पीएचडी थीसिस के लिए सिमुला का उपयोग किया था, अंततः वस्तु-उन्मुख C ++ बनाने के लिए गए।<ref name="Bertrand Meyer 2009 329" /> 1985 में, [[बर्ट्रेंड मेयर]] ने एफिल (प्रोग्रामिंग भाषा) का पहला डिज़ाइन भी तैयार किया। सॉफ्टवेयर गुणवत्ता पर केंद्रित, एफिल विशुद्ध रूप से वस्तु-उन्मुख प्रोग्रामिंग भाषा है और संपूर्ण सॉफ्टवेयर जीवनचक्र का समर्थन करने वाला एक संकेत है। मेयर ने [[वस्तु-उन्मुख सॉफ्टवेयर निर्माण]] में सॉफ्टवेयर इंजीनियरिंग और कंप्यूटर विज्ञान से कुछ प्रमुख विचारों के आधार पर एफिल सॉफ्टवेयर विकास पद्धति का वर्णन किया। एफिल की गुणवत्ता पर ध्यान केंद्रित करने के लिए अनिवार्य है मेयर की विश्वसनीयता तंत्र, [[अनुबंध द्वारा डिजाइन]], जो विधि और भाषा दोनों का एक अभिन्न भाग है।


[[File:Tiobeindex.png|thumb|350px|टीआईओबीई इंडेक्स 2002 से 2018 तक प्रोग्रामिंग भाषा लोकप्रियता ग्राफ को मापता है। 2000 के दशक में वस्तु-उन्मुख जावा (प्रोग्रामिंग भाषा) (हरा) और और प्रक्रियात्मक प्रोग्रामिंग C [[सी (प्रोग्रामिंग भाषा)|(प्रोग्रामिंग भाषा)]] (काला) ने शीर्ष स्थान के लिए प्रतिस्पर्धा की।]]1990 के दशक की प्रारंभ और मध्य में वस्तु-उन्मुख प्रोग्रामिंग प्रमुख प्रोग्रामिंग प्रतिमान के रूप में विकसित हुई जब तकनीकों का समर्थन करने वाली प्रोग्रामिंग भाषाएं व्यापक रूप से उपलब्ध हो गईं। इनमें विजुअल [[फॉक्सप्रो]] 3.0,<ref>1995 (June) Visual [[FoxPro]] 3.0, FoxPro evolves from a procedural language to an object-oriented language. Visual FoxPro 3.0 introduces a database container, seamless client/server capabilities, support for ActiveX technologies, and OLE Automation and null support. [http://www.foxprohistory.org/foxprotimeline.htm#summary_of_fox_releases Summary of Fox releases]</ref><ref>FoxPro History web site: [http://www.foxprohistory.org/tableofcontents.htm Foxprohistory.org]</ref><ref>1995 Reviewers Guide to Visual FoxPro 3.0: [http://www.dfpug.de/loseblattsammlung/migration/whitepapers/vfp_rg.htm DFpug.de]</ref> C ++,<ref>{{Cite book|url=https://books.google.com/books?id=MHmqfSBTXsAC&pg=PA16|title=Object Oriented Programming with C++, 1E|isbn=978-81-259-2532-3|last1=Khurana|first1=Rohit|date=1 November 2009}}</ref> और [[डेल्फी (प्रोग्रामिंग भाषा)]] सम्मिलित है।{{Citation needed|date=February 2010}} [[ग्राफिकल यूज़र इंटरफ़ेस]] की बढ़ती लोकप्रियता से इसका प्रभुत्व और बढ़ गया, जो वस्तु-उन्मुख प्रोग्रामिंग तकनीकों पर बहुत अधिक निर्भर करता है। गुप्त रूप से संबंधित गतिशील जीयूआई पुस्तकालय और वस्तु-उन्मुख प्रोग्रामिंग भाषा का एक उदाहरण मैक ओएस एक्स पर कोको रूपरेखा में पाया जा सकता है, जो ऑब्जेक्टिव-C में लिखा गया है, जो स्मॉलटाक पर आधारित सी के लिए एक ऑब्जेक्ट-ओरिएंटेड, डायनेमिक मैसेजिंग एक्सटेंशन है। वस्तु-उन्मुख प्रोग्रामिंग टूलकिट ने इवेंट-संचालित प्रोग्रामिंग की लोकप्रियता को भी बढ़ाया (हालांकि यह अवधारणा वस्तु-उन्मुख प्रोग्रामिंग तक सीमित नहीं है)।
[[File:Tiobeindex.png|thumb|350px|टीआईओबीई इंडेक्स 2002 से 2018 तक प्रोग्रामिंग भाषा लोकप्रियता ग्राफ को मापता है। 2000 के दशक में वस्तु-उन्मुख जावा (प्रोग्रामिंग भाषा) (हरा) और और प्रक्रियात्मक प्रोग्रामिंग C [[सी (प्रोग्रामिंग भाषा)|(प्रोग्रामिंग भाषा)]] (काला) ने शीर्ष स्थान के लिए प्रतिस्पर्धा की।]]1990 के दशक की प्रारंभ और मध्य में वस्तु-उन्मुख प्रोग्रामिंग प्रमुख प्रोग्रामिंग पैराडिग्म के रूप में विकसित हुई जब तकनीकों का समर्थन करने वाली प्रोग्रामिंग भाषाएं व्यापक रूप से उपलब्ध हो गईं। इनमें विजुअल [[फॉक्सप्रो]] 3.0,<ref>1995 (June) Visual [[FoxPro]] 3.0, FoxPro evolves from a procedural language to an object-oriented language. Visual FoxPro 3.0 introduces a database container, seamless client/server capabilities, support for ActiveX technologies, and OLE Automation and null support. [http://www.foxprohistory.org/foxprotimeline.htm#summary_of_fox_releases Summary of Fox releases]</ref><ref>FoxPro History web site: [http://www.foxprohistory.org/tableofcontents.htm Foxprohistory.org]</ref><ref>1995 Reviewers Guide to Visual FoxPro 3.0: [http://www.dfpug.de/loseblattsammlung/migration/whitepapers/vfp_rg.htm DFpug.de]</ref> C ++,<ref>{{Cite book|url=https://books.google.com/books?id=MHmqfSBTXsAC&pg=PA16|title=Object Oriented Programming with C++, 1E|isbn=978-81-259-2532-3|last1=Khurana|first1=Rohit|date=1 November 2009}}</ref> और [[डेल्फी (प्रोग्रामिंग भाषा)]] सम्मिलित है।{{Citation needed|date=February 2010}} [[ग्राफिकल यूज़र इंटरफ़ेस]] की बढ़ती लोकप्रियता से इसका प्रभुत्व और बढ़ गया, जो वस्तु-उन्मुख प्रोग्रामिंग तकनीकों पर बहुत अधिक निर्भर करता है। गुप्त रूप से संबंधित गतिशील जीयूआई पुस्तकालय और वस्तु-उन्मुख प्रोग्रामिंग भाषा का एक उदाहरण मैक ओएस एक्स पर कोको रूपरेखा में पाया जा सकता है, जो ऑब्जेक्टिव-C में लिखा गया है, जो स्मॉलटाक पर आधारित सी के लिए एक ऑब्जेक्ट-ओरिएंटेड, डायनेमिक मैसेजिंग एक्सटेंशन है। वस्तु-उन्मुख प्रोग्रामिंग टूलकिट ने इवेंट-संचालित प्रोग्रामिंग की लोकप्रियता को भी बढ़ाया (हालांकि यह अवधारणा वस्तु-उन्मुख प्रोग्रामिंग तक सीमित नहीं है)।


ईटीएच ज्यूरिख में, [[निकोलस विर्थ]] और उनके सहयोगी भी डेटा अमूर्तता और [[प्रतिरूपकता (प्रोग्रामिंग)]] जैसे विषयों की जांच कर रहे थे (हालांकि यह 1960 या उससे पहले सामान्य उपयोग में था)। [[मॉड्यूल-2]] (1978) में दोनों सम्मिलित थे, और उनके सफल डिजाइन, ओबेरॉन (प्रोग्रामिंग भाषा) में ऑब्जेक्ट ओरिएंटेशन, क्लासेस और इस तरह के एक विशिष्ट दृष्टिकोण सम्मिलित थे।
ईटीएच ज्यूरिख में, [[निकोलस विर्थ]] और उनके सहयोगी भी डेटा अमूर्तता और [[प्रतिरूपकता (प्रोग्रामिंग)]] जैसे विषयों की जांच कर रहे थे (हालांकि यह 1960 या उससे पहले सामान्य उपयोग में था)। [[मॉड्यूल-2]] (1978) में दोनों सम्मिलित थे, और उनके सफल डिजाइन, ओबेरॉन (प्रोग्रामिंग भाषा) में ऑब्जेक्ट ओरिएंटेशन, क्लासेस और इस तरह के एक विशिष्ट दृष्टिकोण सम्मिलित थे।
Line 111: Line 110:


== विशेषताएं ==
== विशेषताएं ==
वस्तु-उन्मुख प्रोग्रामिंग वस्तुओं का उपयोग करती है, लेकिन सभी संबद्ध तकनीकों और संरचनाओं को प्रत्यक्ष रूप से उन भाषाओं में समर्थित नहीं किया जाता है जो वस्तु-उन्मुख प्रोग्रामिंग का समर्थन करने का दावा करती हैं। यह ऑपरेंड पर संचालन करता है। नीचे सूचीबद्ध विशेषताएं उन भाषाओं में सामान्य हैं जिन्हें दृढ़ता से क्लास-और वस्तु-उन्मुख (या वस्तु-उन्मुख प्रोग्रामिंग समर्थन के साथ बहु-प्रतिमान) माना जाता है, उल्लेखनीय एक्सेप्शन(आक्षेप) का उल्लेख किया गया है।<ref name="ArmstrongQuarks">Deborah J. Armstrong. ''The Quarks of Object-Oriented Development''. A survey of nearly 40 years of computing literature which identified a number of fundamental concepts found in the large majority of definitions of OOP, in descending order of popularity: Inheritance, Object, Class, Encapsulation, Method, Message Passing, Polymorphism, and Abstraction.</ref><ref>[[John C. Mitchell]], ''Concepts in programming languages'', Cambridge University Press, 2003, {{ISBN|0-521-78098-5}}, p.278.  Lists: Dynamic dispatch, abstraction, subtype polymorphism, and inheritance.</ref><ref>Michael Lee Scott, ''Programming language pragmatics'', Edition 2, Morgan Kaufmann, 2006, {{ISBN|0-12-633951-1}}, p. 470.  Lists encapsulation, inheritance, and dynamic dispatch.</ref><ref name="pierce">{{Cite book|last=Pierce|first=Benjamin|title=Types and Programming Languages|publisher=MIT Press|year=2002|isbn=978-0-262-16209-8|title-link=Types and Programming Languages}}, section 18.1 "What is Object-Oriented Programming?"  Lists: Dynamic dispatch, encapsulation or multi-methods (multiple dispatch), subtype polymorphism, inheritance or delegation, open recursion ("this"/"self")</ref>
वस्तु-उन्मुख प्रोग्रामिंग वस्तुओं का उपयोग करती है, लेकिन सभी संबद्ध तकनीकों और संरचनाओं को प्रत्यक्ष रूप से उन भाषाओं में समर्थित नहीं किया जाता है जो वस्तु-उन्मुख प्रोग्रामिंग का समर्थन करने का दावा करती हैं। यह ऑपरेंड पर संचालन करता है। नीचे सूचीबद्ध विशेषताएं उन भाषाओं में सामान्य हैं जिन्हें दृढ़ता से क्लास-और वस्तु-उन्मुख (या वस्तु-उन्मुख प्रोग्रामिंग समर्थन के साथ बहु- पैराडिग्म) माना जाता है, उल्लेखनीय एक्सेप्शन(आक्षेप) का उल्लेख किया गया है।<ref name="ArmstrongQuarks">Deborah J. Armstrong. ''The Quarks of Object-Oriented Development''. A survey of nearly 40 years of computing literature which identified a number of fundamental concepts found in the large majority of definitions of OOP, in descending order of popularity: Inheritance, Object, Class, Encapsulation, Method, Message Passing, Polymorphism, and Abstraction.</ref><ref>[[John C. Mitchell]], ''Concepts in programming languages'', Cambridge University Press, 2003, {{ISBN|0-521-78098-5}}, p.278.  Lists: Dynamic dispatch, abstraction, subtype polymorphism, and inheritance.</ref><ref>Michael Lee Scott, ''Programming language pragmatics'', Edition 2, Morgan Kaufmann, 2006, {{ISBN|0-12-633951-1}}, p. 470.  Lists encapsulation, inheritance, and dynamic dispatch.</ref><ref name="pierce">{{Cite book|last=Pierce|first=Benjamin|title=Types and Programming Languages|publisher=MIT Press|year=2002|isbn=978-0-262-16209-8|title-link=Types and Programming Languages}}, section 18.1 "What is Object-Oriented Programming?"  Lists: Dynamic dispatch, encapsulation or multi-methods (multiple dispatch), subtype polymorphism, inheritance or delegation, open recursion ("this"/"self")</ref>


{{See also|प्रोग्रामिंग भाषाओं की तुलना (वस्तु-उन्मुख प्रोग्रामिंग) और वस्तु-उन्मुख प्रोग्रामिंग शब्दों की सूची}}
{{See also|प्रोग्रामिंग भाषाओं की तुलना (वस्तु-उन्मुख प्रोग्रामिंग) और वस्तु-उन्मुख प्रोग्रामिंग शब्दों की सूची}}
Line 117: Line 116:


=== गैर-वस्तु-उन्मुख प्रोग्रामिंग भाषाओं के साथ साझा ===
=== गैर-वस्तु-उन्मुख प्रोग्रामिंग भाषाओं के साथ साझा ===
* वेरिएबल (चर) जो पूर्णांक (कंप्यूटर विज्ञान) और अक्षरांकीय वर्ण [[चरित्र (कंप्यूटिंग)|(कंप्यूटिंग)]] जैसे अंतर्निर्मित डेटा प्रारूपों की एक छोटी संख्या में स्वरूपित जानकारी को संग्रहीत कर सकता है। इसमें [[स्ट्रिंग (कंप्यूटर विज्ञान)]], [[सूची (सार डेटा प्रकार)]], और [[हैश तालिका]] जैसी [[डेटा संरचनाएं]] सम्मिलित हो सकती हैं जो या तो अंतर्निहित हैं या मेमोरी पॉइंटर (कंप्यूटर प्रोग्रामिंग) का उपयोग करके चर के संयोजन से परिणाम हैं।
* वेरिएबल जो पूर्णांक (कंप्यूटर विज्ञान) और अक्षरांकीय वर्ण [[चरित्र (कंप्यूटिंग)|(कंप्यूटिंग)]] जैसे अंतर्निर्मित डेटा प्रारूपों की एक छोटी संख्या में स्वरूपित जानकारी को संग्रहीत कर सकता है। इसमें [[स्ट्रिंग (कंप्यूटर विज्ञान)]], [[सूची (सार डेटा प्रकार)]], और [[हैश तालिका]] जैसी [[डेटा संरचनाएं]] सम्मिलित हो सकती हैं जो या तो अंतर्निहित हैं या मेमोरी पॉइंटर (कंप्यूटर प्रोग्रामिंग) का उपयोग करके वेरिएबल के संयोजन से परिणाम हैं।
* प्रक्रियाएं - जिन्हें फ़ंक्शंस, विधियों, रूटीन या [[सबरूटीन]]्स के रूप में भी जाना जाता है जो इनपुट लेती हैं, आउटपुट उत्पन्न करती हैं और डेटा में कुशलतापूर्वक प्रयोग करती हैं। आधुनिक भाषाओं में [[लूप (कंप्यूटिंग)]] और सशर्त (कंप्यूटर प्रोग्रामिंग) जैसे [[संरचित प्रोग्रामिंग]] निर्माण सम्मिलित हैं।
* प्रक्रियाएं - जिन्हें फ़ंक्शंस, विधियों, रूटीन या [[सबरूटीन]]्स के रूप में भी जाना जाता है जो इनपुट लेती हैं, आउटपुट उत्पन्न करती हैं और डेटा में कुशलतापूर्वक प्रयोग करती हैं। आधुनिक भाषाओं में [[लूप (कंप्यूटिंग)]] और सशर्त (कंप्यूटर प्रोग्रामिंग) जैसे [[संरचित प्रोग्रामिंग]] निर्माण सम्मिलित हैं।


[[मॉड्यूलर प्रोग्रामिंग]] समर्थन संगठनात्मक उद्देश्यों के लिए फाइलों और मॉड्यूल में समूह प्रक्रियाओं की क्षमता प्रदान करता है। मॉड्यूल नामस्थान हैं इसलिए एक मॉड्यूल में पहचानकर्ता किसी अन्य फ़ाइल या मॉड्यूल में समान नाम साझा करने वाली प्रक्रिया या चर के साथ संघर्ष नहीं करेंगे।
[[मॉड्यूलर प्रोग्रामिंग]] समर्थन संगठनात्मक उद्देश्यों के लिए फाइलों और मॉड्यूल में समूह प्रक्रियाओं की क्षमता प्रदान करता है। मॉड्यूल नामस्थान हैं इसलिए एक मॉड्यूल में पहचानकर्ता किसी अन्य फ़ाइल या मॉड्यूल में समान नाम साझा करने वाली प्रक्रिया या वेरिएबल के साथ संघर्ष नहीं करेंगे।


=== ऑब्जेक्ट्स और क्लासेस ===
=== ऑब्जेक्ट्स और क्लासेस ===
Line 129: Line 128:
वस्तुएं कभी-कभी वास्तविक विश्व में पाई जाने वाली वस्तुओ के अनुरूप होती हैं। उदाहरण के लिए, एक ग्राफिक्स प्रोग्राम में सर्कल, स्क्वायर, मेनू जैसे ऑब्जेक्ट हो सकते हैं। एक ऑनलाइन शॉपिंग प्रणाली में शॉपिंग कार्ट, ग्राहक और उत्पाद जैसी वस्तुएं हो सकती हैं।<ref>{{cite book|last=Booch|first=Grady|title=Software Engineering with Ada|year=1986|publisher=Addison Wesley|isbn=978-0-8053-0608-8|page=220|url=https://en.wikiquote.org/wiki/Grady_Booch|quote=Perhaps the greatest strength of an object-oriented approach to development is that it offers a mechanism that captures a model of the real world.}}</ref> कभी-कभी ऑब्जेक्ट अधिक अमूर्त संस्थाओं का प्रतिनिधित्व करते हैं, जैसे एक ऑब्जेक्ट (वस्तु) जो एक खुली फ़ाइल का प्रतिनिधित्व करता है, या एक ऑब्जेक्ट जो यू.एस. प्रथागत से मीट्रिक में माप का अनुवाद करने की सेवा प्रदान करता है।
वस्तुएं कभी-कभी वास्तविक विश्व में पाई जाने वाली वस्तुओ के अनुरूप होती हैं। उदाहरण के लिए, एक ग्राफिक्स प्रोग्राम में सर्कल, स्क्वायर, मेनू जैसे ऑब्जेक्ट हो सकते हैं। एक ऑनलाइन शॉपिंग प्रणाली में शॉपिंग कार्ट, ग्राहक और उत्पाद जैसी वस्तुएं हो सकती हैं।<ref>{{cite book|last=Booch|first=Grady|title=Software Engineering with Ada|year=1986|publisher=Addison Wesley|isbn=978-0-8053-0608-8|page=220|url=https://en.wikiquote.org/wiki/Grady_Booch|quote=Perhaps the greatest strength of an object-oriented approach to development is that it offers a mechanism that captures a model of the real world.}}</ref> कभी-कभी ऑब्जेक्ट अधिक अमूर्त संस्थाओं का प्रतिनिधित्व करते हैं, जैसे एक ऑब्जेक्ट (वस्तु) जो एक खुली फ़ाइल का प्रतिनिधित्व करता है, या एक ऑब्जेक्ट जो यू.एस. प्रथागत से मीट्रिक में माप का अनुवाद करने की सेवा प्रदान करता है।


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


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


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


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


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


=== गतिशील प्रेषण/[[संदेश देना]] ===
=== गतिशील प्रेषण/[[संदेश देना]] ===
Line 155: Line 154:
डेटा अमूर्तता एक डिज़ाइन पैटर्न है जिसमें डेटा केवल सेमेन्टिक्स से संबंधित फंक्शन के लिए दृश्यमान होता है, ताकि दुरुपयोग को रोका जा सके। डेटा अमूर्तता की सफलता वस्तु उन्मुख और शुद्ध कार्यात्मक प्रोग्रामिंग में एक डिजाइन सिद्धांत के रूप में सूचना छिपाने के निरंतर समावेश की ओर ले जाती है।
डेटा अमूर्तता एक डिज़ाइन पैटर्न है जिसमें डेटा केवल सेमेन्टिक्स से संबंधित फंक्शन के लिए दृश्यमान होता है, ताकि दुरुपयोग को रोका जा सके। डेटा अमूर्तता की सफलता वस्तु उन्मुख और शुद्ध कार्यात्मक प्रोग्रामिंग में एक डिजाइन सिद्धांत के रूप में सूचना छिपाने के निरंतर समावेश की ओर ले जाती है।


यदि कोई क्लास कॉलिंग कोड को आंतरिक वस्तु डेटा तक अभिगम्य की स्वीकृति नहीं देता है और केवल विधियों के माध्यम से अभिगम्य की स्वीकृति देता है, तो यह जानकारी छिपाने का एक रूप है जिसे अमूर्त (कंप्यूटर विज्ञान) के रूप में जाना जाता है। कुछ भाषाएँ (उदाहरण के लिए जावा) क्लास को स्पष्ट रूप से पहुँच प्रतिबंधों को लागू करने देती हैं, उदाहरण के लिए <code>private</code> कीवर्ड के साथ आंतरिक डेटा को निरूपित करना और <code>public</code> कीवर्ड के साथ क्लास के बाहर कोड द्वारा उपयोग के लिए अभिप्रेत विधियों को निर्दिष्ट करना। विधियों को सार्वजनिक, निजी या मध्यवर्ती स्तरों जैसे <code>protected</code> (जो एक ही क्लास और उसके सबक्लास से अभिगम्य की स्वीकृति देता है, लेकिन एक अलग क्लास की वस्तुओं की स्वीकृति नहीं है) को भी डिज़ाइन किया जा सकता है। अन्य भाषाओं में (जैसे पायथन) यह केवल समागम द्वारा लागू किया जाता है (उदाहरण के लिए, <code>private</code> विधियों में नाम हो सकते हैं जो [[बल देना]] से प्रारंभ होते हैं)। C #, स्विफ्ट और कोटलिन भाषाओं में, <code>internal</code> कीवर्ड केवल उसी असेंबली, पैकेज या मॉड्यूल में सम्मिलित फाइलों तक पहुंच की स्वीकृति देता है, जो क्लास के रूप में होती है।<ref>{{Cite web |date=2023-01-05 |title=What is Object Oriented Programming (OOP) In Simple Words? – Software Geek Bytes |url=https://softwaregeekbytes.com/object-oriented-programming-simple-words/ |access-date=2023-01-17 |language=en-US}}</ref>
यदि कोई क्लास कॉलिंग कोड को आंतरिक वस्तु डेटा तक अभिगम्य की स्वीकृति नहीं देता है और केवल विधियों के माध्यम से अभिगम्य की स्वीकृति देता है, तो यह जानकारी छिपाने का एक रूप है जिसे अमूर्त (कंप्यूटर विज्ञान) के रूप में जाना जाता है। कुछ भाषाएँ (उदाहरण के लिए जावा) क्लास को स्पष्ट रूप से पहुँच प्रतिबंधों को प्रयुक्त करने देती हैं, उदाहरण के लिए <code>private</code> कीवर्ड के साथ आंतरिक डेटा को निरूपित करना और <code>public</code> कीवर्ड के साथ क्लास के बाहर कोड द्वारा उपयोग के लिए अभिप्रेत विधियों को निर्दिष्ट करना। विधियों को सार्वजनिक, निजी या मध्यवर्ती स्तरों जैसे <code>protected</code> (जो एक ही क्लास और उसके सबक्लास से अभिगम्य की स्वीकृति देता है, लेकिन एक अलग क्लास की वस्तुओं की स्वीकृति नहीं है) को भी डिज़ाइन किया जा सकता है। अन्य भाषाओं में (जैसे पायथन) यह केवल समागम द्वारा प्रयुक्त किया जाता है (उदाहरण के लिए, <code>private</code> विधियों में नाम हो सकते हैं जो [[बल देना]] से प्रारंभ होते हैं)। C #, स्विफ्ट और कोटलिन भाषाओं में, <code>internal</code> कीवर्ड केवल उसी असेंबली, पैकेज या मॉड्यूल में सम्मिलित फाइलों तक पहुंच की स्वीकृति देता है, जो क्लास के रूप में होती है।<ref>{{Cite web |date=2023-01-05 |title=What is Object Oriented Programming (OOP) In Simple Words? – Software Geek Bytes |url=https://softwaregeekbytes.com/object-oriented-programming-simple-words/ |access-date=2023-01-17 |language=en-US}}</ref>




=== कैप्सूलीकरण ===
=== कैप्सूलीकरण ===


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


=== संरचना, विरासत, और प्रतिनिधिमंडल ===
=== संरचना, इनहेरिटेंस, और डेलिगेशन ===
वस्तुओं में उनके उदाहरण चर में अन्य वस्तुएँ हो सकती हैं; इसे [[वस्तु रचना]] के रूप में जाना जाता है। उदाहरण के लिए, कर्मचारी क्लास में एक वस्तु में (या तो सीधे या एक सूचक के माध्यम से) पता क्लास में एक वस्तु हो सकती है, इसके अतिरिक्त अपने स्वयं के उदाहरण चर जैसे first_name और स्थिति। ऑब्जेक्ट संरचना का उपयोग संबंधों को दर्शाने के लिए किया जाता है: प्रत्येक कर्मचारी का एक पता होता है, इसलिए प्रत्येक कर्मचारी ऑब्जेक्ट के पास एड्रेस ऑब्जेक्ट स्टोर करने के लिए एक जगह तक पहुंच होती है (या तो सीधे अपने भीतर एम्बेड किया जाता है, या एक पॉइंटर के माध्यम से संबोधित एक अलग स्थान पर)।
ऑब्जेक्ट्स में उनके इंस्टेंस वेरिएबल्स में अन्य ऑब्जेक्ट्स हो सकते हैं इसे ऑब्जेक्ट [[वस्तु रचना|(वस्तु) रचना]] के रूप में जाना जाता है। उदाहरण के लिए, उपयोगकर्ता क्लास में एक ऑब्जेक्ट में "पहला नाम" और स्थिति जैसे अपने इंस्टेंस वेरिएबल्स के अतिरिक्त (या तो प्रत्यक्ष रूप से या एक सूचक के माध्यम से) एड्रैस क्लास में एक वस्तु हो सकती है। ऑब्जेक्ट संरचना का उपयोग संबंधों को दर्शाने के लिए किया जाता है: प्रत्येक उपयोगकर्ता का एक एड्रैस होता है, इसलिए प्रत्येक उपयोगकर्ता ऑब्जेक्ट के पास एड्रेस ऑब्जेक्ट संग्रहित करने के लिए एक जगह तक अभिगम्य होती है (या तो प्रत्यक्ष रूप से अपने अंदर एम्बेड किया जाता है, या एक पॉइंटर के माध्यम से संबोधित एक अलग स्थान पर)।


क्लास का समर्थन करने वाली भाषाएं लगभग हमेशा इनहेरिटेंस (वस्तु-उन्मुख प्रोग्रामिंग) का समर्थन करती हैं। यह क्लास को एक पदानुक्रम में व्यवस्थित करने की स्वीकृति देता है जो कि एक प्रकार के संबंधों का प्रतिनिधित्व करता है। उदाहरण के लिए, क्लास कर्मचारी क्लास व्यक्ति से प्राप्त हो सकता है। पैरेंट क्लास के लिए उपलब्ध सभी डेटा और मेथड्स चाइल्ड क्लास में भी उन्हीं नामों के साथ दिखाई देते हैं। उदाहरण के लिए, क्लास व्यक्ति चर first_name और last_name को विधि make_full_name() के साथ परिभाषित कर सकता है। ये क्लास कर्मचारी में भी उपलब्ध होंगे, जो चर स्थिति और वेतन जोड़ सकते हैं। यह तकनीक एक सहज तरीके से वास्तविक विश्व के रिश्तों को संभावित रूप से प्रतिबिंबित करने के अतिरिक्त समान प्रक्रियाओं और डेटा परिभाषाओं के आसान पुन: उपयोग की स्वीकृति देती है। डेटाबेस टेबल और प्रोग्रामिंग सबरूटीन्स का उपयोग करने के अतिरिक्त, डेवलपर उन वस्तुओं का उपयोग करता है जिनसे उपयोगकर्ता अधिक परिचित हो सकता है: उनके एप्लिकेशन डोमेन से ऑब्जेक्ट।<ref>{{cite book|last=Jacobsen|first=Ivar|title=Object Oriented Software Engineering|year=1992|publisher=Addison-Wesley ACM Press|isbn=978-0-201-54435-0|pages=[https://archive.org/details/objectorientedso00jaco/page/43 43–69]|author2=Magnus Christerson|author3=Patrik Jonsson|author4=Gunnar Overgaard|url=https://archive.org/details/objectorientedso00jaco/page/43}}</ref>
क्लास का समर्थन करने वाली भाषाएं लगभग हमेशा इनहेरिटेंस (वस्तु-उन्मुख प्रोग्रामिंग) का समर्थन करती हैं। यह क्लास को एक पदानुक्रम में व्यवस्थित करने की स्वीकृति देता है जो कि एक प्रकार के संबंधों का प्रतिनिधित्व करता है। उदाहरण के लिए, क्लास उपयोगकर्ता क्लास व्यक्ति से प्राप्त हो सकता है। पैरेंट क्लास के लिए उपलब्ध सभी डेटा और मेथड्स चाइल्ड क्लास में भी उन्हीं नामों के साथ दिखाई देते हैं। उदाहरण के लिए, क्लास व्यक्ति वेरिएबल पहला नाम और "उपनाम" को "मेक_फुल_नाम ()" विधि के साथ परिभाषित कर सकता है। ये क्लास उपयोगकर्ता में भी उपलब्ध होंगे, जो वेरिएबल स्थिति और वेतन जोड़ सकते हैं। यह तकनीक एक सहज तरीके से वास्तविक विश्व के संबंधों को संभावित रूप से प्रतिबिंबित करने के अतिरिक्त समान प्रक्रियाओं और डेटा परिभाषाओं के आसान पुन: उपयोग की स्वीकृति देती है। डेटाबेस सारणी और प्रोग्रामिंग सबरूटीन्स का उपयोग करने के अतिरिक्त, विकासक उन वस्तुओं का उपयोग करता है जो उपयोगकर्ता उनके एप्लिकेशन डोमेन से ऑब्जेक्ट से अधिक परिचित हो सकते हैं।<ref>{{cite book|last=Jacobsen|first=Ivar|title=Object Oriented Software Engineering|year=1992|publisher=Addison-Wesley ACM Press|isbn=978-0-201-54435-0|pages=[https://archive.org/details/objectorientedso00jaco/page/43 43–69]|author2=Magnus Christerson|author3=Patrik Jonsson|author4=Gunnar Overgaard|url=https://archive.org/details/objectorientedso00jaco/page/43}}</ref>
सबक्लास सुपरक्लास द्वारा परिभाषित विधियों को ओवरराइड कर सकते हैं। कुछ भाषाओं में एकाधिक इनहेरिटेंस की स्वीकृति है, हालांकि यह समाधान को ओवरराइड को जटिल बना सकता है। कुछ भाषाओं में मिश्रण के लिए विशेष समर्थन होता है, हालांकि किसी भी भाषा में एकाधिक इनहेरिटेंस के साथ, एक मिश्रण केवल एक क्लास है जो एक प्रकार के संबंध का प्रतिनिधित्व नहीं करता है। मिक्सिन्स का उपयोग सामान्य रूप से एक ही तरीके को कई क्लासेस में जोड़ने के लिए किया जाता है। उदाहरण के लिए, क्लास FileReader और क्लास WebPageScraper में सम्मिलित होने पर, क्लास UnicodeConversionMixin एक विधि unicode_to_ascii() प्रदान कर सकता है, जो एक सामान्य माता-पिता को साझा नहीं करता है।


[[सार वर्ग|सार]] क्लासेस को वस्तुओं में तत्काल नहीं किया जा सकता है; वे केवल अन्य ठोस क्लासेस में इनहेरिटेंस के उद्देश्य से सम्मिलित हैं जिन्हें तत्काल किया जा सकता है। जावा में, <code>[[final (Java)|final]]</code> किसी क्लास को उपवर्गित होने से रोकने के लिए कीवर्ड का उपयोग किया जा सकता है।
सबक्लास सुपरक्लास द्वारा परिभाषित विधियों को ओवरराइड कर सकते हैं। कुछ भाषाओं में एकाधिक इनहेरिटेंस की स्वीकृति है, हालांकि यह समाधान को ओवरराइड को जटिल बना सकता है। कुछ भाषाओं में मिक्सिन के लिए विशेष समर्थन होता है, हालांकि किसी भी भाषा में एकाधिक इनहेरिटेंस के साथ, एक मिक्सिन केवल एक क्लास है जो एक प्रकार के संबंध का प्रतिनिधित्व नहीं करता है। मिक्सिन्स का उपयोग सामान्य रूप से एक ही तरीके को कई क्लासेस में जोड़ने के लिए किया जाता है। उदाहरण के लिए, क्लास फाइलरीडर और क्लास वेबपेजस्क्रेपर में सम्मिलित होने पर, क्लास यूनिकोडकनवर्जनमिक्सिन एक विधि यूनिकोड_से_एससीआईआई () प्रदान कर सकता है, जो एक सामान्य पैरेंट को साझा नहीं करता है।


[[वंशानुक्रम पर रचना|इनहेरिटेंस पर रचना]] का सिद्धांत इनहेरिटेंस के अतिरिक्त रचना का उपयोग करके है-एक संबंध को लागू करने की वकालत करता है। उदाहरण के लिए, क्लास पर्सन से इनहेरिट करने के अतिरिक्त, क्लास एंप्लॉयी प्रत्येक एंप्लॉयी ऑब्जेक्ट को एक इंटरनल पर्सन ऑब्जेक्ट दे सकता है, जिसे तब बाहरी कोड से छिपाने का अवसर मिलता है, भले ही क्लास पर्सन के पास कई सार्वजनिक विशेषताएँ या विधियाँ हों। कुछ भाषाएँ, जैसे गो (प्रोग्रामिंग भाषा) विरासत का समर्थन बिल्कुल नहीं करती हैं।
[[सार वर्ग|सार]] क्लासेस को वस्तुओं में तत्काल नहीं किया जा सकता है; वे केवल अन्य एसओएलआईडी क्लासेस में इनहेरिटेंस के उद्देश्य से सम्मिलित हैं जिन्हें तत्काल किया जा सकता है। जावा में, किसी क्लास को सबक्लासेस होने से रोकने के लिए <code>[[final (Java)|final]]</code>कीवर्ड का उपयोग किया जा सकता है।


खुला/बंद सिद्धांत इस बात की वकालत करता है कि कक्षाएं और फंक्शन विस्तार के लिए खुले होने चाहिए, लेकिन संशोधन के लिए बंद होने चाहिए।
[[वंशानुक्रम पर रचना|इनहेरिटेंस पर रचना]] का सिद्धांत इनहेरिटेंस के अतिरिक्त रचना का उपयोग करके संबंध को प्रयुक्त करने को समर्थन करता है। उदाहरण के लिए, क्लास पर्सन से इनहेरिट करने के अतिरिक्त, क्लास एंप्लॉयी प्रत्येक एंप्लॉयी ऑब्जेक्ट को एक इंटरनल पर्सन ऑब्जेक्ट दे सकता है, जिसे तब बाहरी कोड से छिपाने का अवसर मिलता है, तथापि क्लास पर्सन के पास कई सार्वजनिक विशेषताएँ या विधियाँ हों। कुछ भाषाएँ, जैसे गो (प्रोग्रामिंग भाषा) इनहेरिटेंस का समर्थन नहीं करती हैं।


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


=== बहुरूपता ===
=== बहुरूपता ===
उपप्रकार - [[बहुरूपता (कंप्यूटर विज्ञान)]] का एक रूप - जब कॉलिंग कोड स्वतंत्र हो सकता है कि समर्थित पदानुक्रम में यह किस क्लास पर काम कर रहा है - मूल क्लास या उसके वंश में से एक। इस बीच, विरासत पदानुक्रम में वस्तुओं के बीच एक ही ऑपरेशन का नाम अलग-अलग गतिविधि कर सकता है।
सबटाइपिंग - [[बहुरूपता (कंप्यूटर विज्ञान)]] का एक रूप तब होता है जब कॉलिंग कोड समर्थित पदानुक्रम में किस क्लास से स्वतंत्र हो सकता है, यह पैरेंट क्लास या उसके डिसेंडेंट में से एक पर काम कर रहा है। इस बीच, इनहेरिटेंस पदानुक्रम में वस्तुओं के बीच एक ही संचालन का नाम अलग-अलग गतिविधि कर सकता है।


उदाहरण के लिए, वृत्त और क्लास प्रकार की वस्तुएँ आकार नामक एक सामान्य क्लास से ली गई हैं। प्रत्येक प्रकार के आकार के लिए ड्रा फ़ंक्शन लागू होता है जो स्वयं को आकर्षित करने के लिए आवश्यक होता है जबकि कॉलिंग कोड किसी विशेष प्रकार के आकार को आकर्षित करने के प्रति उदासीन रह सकता है।
उदाहरण के लिए, वृत्त और वर्ग प्रकार की वस्तुएँ आकार नामक एक सामान्य क्लास से ली गई हैं। प्रत्येक प्रकार के आकार के लिए ड्रा फ़ंक्शन प्रयुक्त होता है जो स्वयं को आकर्षित करने के लिए आवश्यक होता है जबकि कॉलिंग कोड किसी विशेष प्रकार के आकार को आकर्षित करने के प्रति सामान्य रह सकता है।


यह एक अन्य प्रकार का अमूर्त है जो क्लास पदानुक्रम के बाहर के कोड को सरल करता है और चिंताओं के मजबूत पृथक्करण को सक्षम बनाता है।
यह एक अन्य प्रकार का अमूर्त है जो क्लास पदानुक्रम के बाहर के कोड को सामान्य करता है और प्रयोजन के दृढ़ता से अंतर को सक्षम बनाता है।


=== [[खुला पुनरावर्तन]] ===
=== [[खुला पुनरावर्तन]] ===
ओपन रिकर्सन का समर्थन करने वाली भाषाओं में, ऑब्जेक्ट मेथड्स एक ही ऑब्जेक्ट (स्वयं सहित) पर अन्य तरीकों को कॉल कर सकते हैं, सामान्य रूप से एक विशेष चर या कीवर्ड का उपयोग करते हुए कहा जाता है <code>this</code> या <code>self</code>. यह वेरिएबल [[नाम बंधन]]|लेट-बाउंड; यह एक क्लास में परिभाषित एक विधि को दूसरी विधि का आह्वान करने की स्वीकृति देता है जिसे बाद में उसके कुछ उपवर्गों में परिभाषित किया गया है।
[[खुला पुनरावर्तन]] का समर्थन करने वाली भाषाओं में, ऑब्जेक्ट विधि एक ही ऑब्जेक्ट (स्वयं सहित) पर अन्य तरीकों को कॉल कर सकते हैं, सामान्य रूप से एक विशेष वेरिएबल या कीवर्ड का उपयोग करते है जिसे <code>this</code> या <code>self</code> कहा जाता है। वेरिएबल लेट-बाउंड है यह एक क्लास में परिभाषित एक विधि को दूसरी विधि को प्रयुक्त करने की स्वीकृति देता है जिसे बाद में उसके कुछ सबक्लास में परिभाषित किया गया है।


== वस्तु-उन्मुख प्रोग्रामिंग भाषाएं ==
== वस्तु-उन्मुख प्रोग्रामिंग भाषाएं ==
{{See also|List of object-oriented programming languages}}
{{See also|वस्तु-उन्मुख प्रोग्रामिंग भाषाओं की सूची}}
सिमुला (1967) को सामान्य रूप से वस्तु-उन्मुख भाषा की प्राथमिक विशेषताओं वाली पहली भाषा के रूप में स्वीकार किया जाता है। यह [[कंप्यूटर सिमुलेशन]] बनाने के लिए बनाया गया था, जिसमें वस्तुओं को सबसे महत्वपूर्ण सूचना प्रतिनिधित्व कहा जाने लगा। स्मॉलटाक (1972 से 1980) एक और प्रारंभिक उदाहरण है, और वह जिसके साथ वस्तु-उन्मुख प्रोग्रामिंग के अधिकांश सिद्धांत विकसित किए गए थे। वस्तु अभिविन्यास की डिग्री के संबंध में, निम्नलिखित भेद किए जा सकते हैं:
सिमुला (1967) को सामान्य रूप से वस्तु-उन्मुख भाषा की प्राथमिक विशेषताओं वाली पहली भाषा के रूप में स्वीकार किया जाता है। यह [[कंप्यूटर सिमुलेशन]] बनाने के लिए बनाया गया था, जिसमें वस्तुओं को सबसे महत्वपूर्ण सूचना प्रतिनिधित्व कहा जाने लगा। स्मॉलटाक (1972 से 1980) एक और प्रारंभिक उदाहरण है, और वह जिसके साथ वस्तु-उन्मुख प्रोग्रामिंग के अधिकांश सिद्धांत विकसित किए गए थे। ऑब्जेक्ट ओरिएंटेशन की डिग्री के संबंध में, निम्नलिखित भेद किए जा सकते हैं:


* शुद्ध वस्तु-उन्मुख भाषाएँ कहलाने वाली भाषाएँ, क्योंकि उनमें सब कुछ एक वस्तु के रूप में निरंतर गतिविधि किया जाता है, आदिम से लेकर वर्ण और विराम चिह्न तक, सभी तरह से पूरी क्लास, प्रोटोटाइप, ब्लॉक, मॉड्यूल आदि तक। वे विशेष रूप से सुविधा के लिए डिज़ाइन किए गए थे, यहाँ तक कि लागू करें, वस्तु-उन्मुख तरीके। उदाहरण: रूबी (प्रोग्रामिंग भाषा), स्काला (प्रोग्रामिंग भाषा), स्मॉलटाक, एफिल (प्रोग्रामिंग भाषा), [[पन्ना (प्रोग्रामिंग भाषा)]],<ref>{{cite web|url=http://www.emeraldprogramminglanguage.org/|title=The Emerald Programming Language| date=26 February 2011}}</ref> JADE (प्रोग्रामिंग भाषा), [[स्वयं (प्रोग्रामिंग भाषा)]], राकू (प्रोग्रामिंग भाषा)।
* शुद्ध वस्तु-उन्मुख भाषाएँ कहलाने वाली भाषाएँ, क्योंकि उनमें सब कुछ एक वस्तु के रूप में निरंतर गतिविधि किया जाता है, मौलिक से लेकर वर्ण और विराम चिह्न तक, पूरी क्लास, प्रोटोटाइप, ब्लॉक, मॉड्यूल आदि तक तिविधि करते है। वे विशेष रूप से वस्तु-उन्मुख तरीके सुविधा के लिए डिज़ाइन किए गए थे, यहाँ तक कि प्रयुक्त करने के लिए प्रयुक्त किए गए थे। उदाहरण: रूबी (प्रोग्रामिंग भाषा), स्काला (प्रोग्रामिंग भाषा), स्मॉलटाक, एफिल (प्रोग्रामिंग भाषा), [[पन्ना (प्रोग्रामिंग भाषा)]],<ref>{{cite web|url=http://www.emeraldprogramminglanguage.org/|title=The Emerald Programming Language| date=26 February 2011}}</ref> जेएडीए (प्रोग्रामिंग भाषा), [[स्वयं (प्रोग्रामिंग भाषा)|सेल्फ (प्रोग्रामिंग भाषा)]], राकू (प्रोग्रामिंग भाषा)।
* मुख्य रूप से वस्तु-उन्मुख प्रोग्रामिंग के लिए डिज़ाइन की गई भाषाएँ, लेकिन कुछ प्रक्रियात्मक तत्वों के साथ। उदाहरण: जावा (प्रोग्रामिंग भाषा), पायथन (प्रोग्रामिंग भाषा), सी++, सी शार्प (प्रोग्रामिंग भाषा)|सी#, डेल्फी (प्रोग्रामिंग भाषा)/ऑब्जेक्ट पास्कल, वीबी.नेट।
* मुख्य रूप से वस्तु-उन्मुख प्रोग्रामिंग के लिए भाषाएँ, लेकिन कुछ प्रक्रियात्मक तत्वों के साथ डिज़ाइन की गई। उदाहरण: जावा (प्रोग्रामिंग भाषा), पायथन (प्रोग्रामिंग भाषा), C++, C# (प्रोग्रामिंग भाषा), डेल्फी (प्रोग्रामिंग भाषा)/ऑब्जेक्ट पास्कल, वीबी.नेट।
* भाषाएँ जो ऐतिहासिक रूप से प्रक्रियात्मक प्रोग्रामिंग हैं, लेकिन कुछ वस्तु-उन्मुख सुविधाओं के साथ विस्तारित की गई हैं। उदाहरण: PHP, पर्ल, [[मूल दृश्य]] (बेसिक से प्राप्त), MATLAB, [[COBOL 2002]], [[फोरट्रान 2003]], [[ABAP]], एडीए (प्रोग्रामिंग भाषा), पास्कल (प्रोग्रामिंग भाषा)।
* भाषाएँ जो ऐतिहासिक रूप से प्रक्रियात्मक प्रोग्रामिंग हैं, लेकिन कुछ वस्तु-उन्मुख सुविधाओं के साथ विस्तारित की गई हैं। उदाहरण: पीएचपी, पर्ल, विज़ुअल बेसिक (बेसिक से प्राप्त), एमएटीएलएबी, [[COBOL 2002|कोबोल 2002]], [[फोरट्रान 2003]], [[ABAP|एबीएपी]], एडीए (प्रोग्रामिंग भाषा), पास्कल (प्रोग्रामिंग भाषा)।
* वस्तुओं (क्लासेस, विधियों, विरासत) की अधिकांश विशेषताओं वाली भाषाएँ, लेकिन एक विशिष्ट मूल रूप में। उदाहरण: ओबेरॉन (प्रोग्रामिंग भाषा) (ओबेरॉन-1 या ओबेरॉन-2)।
* वस्तुओं (क्लासेस, विधियों, इनहेरिटेंस) की अधिकांश विशेषताओं वाली भाषाएँ, लेकिन एक विशिष्ट मूल रूप में है। उदाहरण: ओबेरॉन (प्रोग्रामिंग भाषा) (ओबेरॉन-1 या ओबेरॉन-2)।
* अमूर्त डेटा प्रकार समर्थन वाली भाषाएँ जिनका उपयोग वस्तु-उन्मुख प्रोग्रामिंग के समान करने के लिए किया जा सकता है, लेकिन ऑब्जेक्ट-ओरिएंटेशन की सभी विशेषताओं के बिना। इसमें ऑब्जेक्ट-आधारित|ऑब्जेक्ट-आधारित और प्रोटोटाइप-आधारित प्रोग्रामिंग|प्रोटोटाइप-आधारित भाषाएं सम्मिलित हैं। उदाहरण: JavaScript, Lua (प्रोग्रामिंग भाषा), Modula-2, CLU (प्रोग्रामिंग भाषा)।
* अमूर्त डेटा प्रकार समर्थन वाली भाषाएँ जिनका उपयोग वस्तु-उन्मुख प्रोग्रामिंग के समान करने के लिए किया जा सकता है, लेकिन ऑब्जेक्ट-ओरिएंटेशन की सभी विशेषताओं के बिना किया जा सकता है। इसमें ऑब्जेक्ट-आधारित और प्रोटोटाइप-आधारित प्रोग्रामिंग भाषाएं सम्मिलित हैं। उदाहरण: जावास्क्रिप्ट, लुआ (प्रोग्रामिंग भाषा), मोडुला-2, सीएलयू (प्रोग्रामिंग भाषा)।
* गिरगिट भाषाएँ जो वस्तु-उन्मुख सहित कई प्रतिमानों का समर्थन करती हैं। [[Tcl]]OO के लिए इनमें से Tcl सबसे अलग है, एक हाइब्रिड ऑब्जेक्ट प्रणाली जो प्रोटोटाइप-आधारित प्रोग्रामिंग और क्लास-आधारित वस्तु-उन्मुख दोनों का समर्थन करता है।
* चमेलेन भाषाएँ जो वस्तु-उन्मुख सहित कई पैराडिग्म का समर्थन करती हैं। टीसीएलओओ के लिए इनमें से टीसीएल सबसे अलग है, एक हाइब्रिड ऑब्जेक्ट प्रणाली जो प्रोटोटाइप-आधारित प्रोग्रामिंग और क्लास-आधारित वस्तु-उन्मुख दोनों का समर्थन करता है।


=== गतिशील भाषाओं में वस्तु-उन्मुख प्रोग्रामिंग ===
=== गतिशील भाषाओं में वस्तु-उन्मुख प्रोग्रामिंग ===
हाल के वर्षों में, वस्तु-उन्मुख प्रोग्रामिंग [[गतिशील प्रोग्रामिंग भाषा]]ओं में विशेष रूप से लोकप्रिय हो गई है। पायथन (प्रोग्रामिंग भाषा), [[विंडोज पॉवरशेल]], रूबी (प्रोग्रामिंग भाषा) और [[ग्रूवी (प्रोग्रामिंग भाषा)]] वस्तु-उन्मुख प्रोग्रामिंग सिद्धांतों पर निर्मित गतिशील भाषाएं हैं, जबकि पर्ल और पीएचपी पर्ल 5 और पीएचपी 4 के बाद से वस्तु-उन्मुख फीचर जोड़ रहे हैं, और संस्करण के बाद से [[ठंडा गलन]] 6.
हाल के वर्षों में, वस्तु-उन्मुख प्रोग्रामिंग [[गतिशील प्रोग्रामिंग भाषा]]ओं में विशेष रूप से लोकप्रिय हो गई है। पायथन (प्रोग्रामिंग भाषा), [[विंडोज पॉवरशेल]], रूबी (प्रोग्रामिंग भाषा) और [[ग्रूवी (प्रोग्रामिंग भाषा)]] वस्तु-उन्मुख प्रोग्रामिंग सिद्धांतों पर निर्मित गतिशील भाषाएं हैं, जबकि पर्ल और पीएचपी पर्ल 5 और पीएचपी 4 के बाद से वस्तु-उन्मुख फीचर्स और संस्करण 6 के बाद से कोल्डफ्यूजन जोड़ रहे हैं।


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


=== एक नेटवर्क प्रोटोकॉल में वस्तु-उन्मुख प्रोग्रामिंग ===
=== एक नेटवर्क प्रोटोकॉल में वस्तु-उन्मुख प्रोग्रामिंग ===
क्लाइंट-सर्वर वातावरण में सेवाओं का अनुरोध करने के लिए कंप्यूटर के बीच प्रवाहित होने वाले संदेशों को क्लाइंट और सर्वर दोनों के लिए ज्ञात क्लास वस्तुओं द्वारा परिभाषित वस्तुओं के रैखिककरण के रूप में डिज़ाइन किया जा सकता है। उदाहरण के लिए, एक साधारण रेखीयकृत वस्तु में एक लम्बाई क्षेत्र, क्लास की पहचान करने वाला एक कोड बिंदु और एक डेटा मान सम्मिलित होगा। एक अधिक जटिल उदाहरण एक कमांड होगा जिसमें कमांड की लंबाई और कोड बिंदु और कमांड के पैरामीटर का प्रतिनिधित्व करने वाले रैखिक वस्तुओं से युक्त मूल्य सम्मिलित होंगे। ऐसे प्रत्येक आदेश को सर्वर द्वारा उस वस्तु के लिए निर्देशित किया जाना चाहिए जिसका क्लास (या सुपरक्लास) आदेश को पहचानता है और अनुरोधित सेवा प्रदान करने में सक्षम है। ग्राहकों और सर्वरों को जटिल वस्तु-उन्मुख संरचनाओं के रूप में सर्वोत्तम रूप से तैयार किया जाता है। वितरित डेटा प्रबंधन संरचना (डीडीएम) ने इस दृष्टिकोण को अपनाया और औपचारिक पदानुक्रम के चार स्तरों पर वस्तुओं को परिभाषित करने के लिए क्लास ऑब्जेक्ट्स का इस्तेमाल किया:
क्लाइंट-सर्वर वातावरण में सेवाओं का इंस्टेंस करने के लिए कंप्यूटर के बीच प्रवाहित होने वाले संदेशों को क्लाइंट और सर्वर दोनों के लिए ज्ञात क्लास वस्तुओं द्वारा परिभाषित वस्तुओं के रैखिककरण के रूप में डिज़ाइन किया जा सकता है। उदाहरण के लिए, एक साधारण रेखीयकृत वस्तु में एक लम्बाई क्षेत्र, क्लास की पहचान करने वाला एक कोड बिंदु और एक डेटा मान सम्मिलित होगा। एक अधिक जटिल उदाहरण एक कमांड होगा जिसमें कमांड की लंबाई और कोड बिंदु और कमांड के पैरामीटर का प्रतिनिधित्व करने वाले रैखिक वस्तुओं से युक्त मूल्य सम्मिलित होंगे। ऐसे प्रत्येक आदेश को सर्वर द्वारा उस वस्तु के लिए निर्देशित किया जाना चाहिए जिसका क्लास (या सुपरक्लास) आदेश को पहचानता है और अनुरोधित सेवा प्रदान करने में सक्षम है। ग्राहकों और सर्वरों को जटिल वस्तु-उन्मुख संरचनाओं के रूप में सर्वोत्तम रूप से तैयार किया जाता है। वितरित डेटा प्रबंधन संरचना (डीडीएम) ने इस दृष्टिकोण को स्वीकार किया और औपचारिक पदानुक्रम के चार स्तरों पर वस्तुओं को परिभाषित करने के लिए क्लास ऑब्जेक्ट्स का उपयोग किया:
* संदेश बनाने वाले डेटा मानों को परिभाषित करने वाले क्षेत्र, जैसे कि उनकी लंबाई, कोड बिंदु और डेटा मान।
* संदेश बनाने वाले डेटा मानों को परिभाषित करने वाले क्षेत्र, जैसे कि उनकी लंबाई, कोड बिंदु और डेटा मान।
* संदेश और मापदंडों के लिए स्मॉलटाक प्रोग्राम में जो मिलेगा उसके समान वस्तुओं का संग्रह और संग्रह।
* संदेश और मापदंडों के लिए स्मॉलटाक प्रोग्राम में जो मिलेगा उसके समान वस्तुओं का संग्रह
* [[IBM i]] [[Object (IBM i)]] के समान प्रबंधक, जैसे मेटाडेटा और रिकॉर्ड वाली फ़ाइलों और फ़ाइलों की निर्देशिका। प्रबंधक अवधारणात्मक रूप से अपनी निहित वस्तुओं के लिए मेमोरी और प्रोसेसिंग संसाधन प्रदान करते हैं।
* [[IBM i|अंतर्राष्ट्रीय व्यापार मशीनें निगम i]] ऑब्जेक्ट्स के समान प्रबंधक, जैसे मेटाडेटा और रिकॉर्ड वाली फ़ाइलों और फ़ाइलों की निर्देशिका है। प्रबंधक अवधारणात्मक रूप से अपनी निहित वस्तुओं के लिए मेमोरी और प्रोसेसिंग संसाधन प्रदान करते हैं।
* एक क्लाइंट या सर्वर जिसमें एक पूर्ण प्रसंस्करण वातावरण को लागू करने के लिए आवश्यक सभी प्रबंधक सम्मिलित हैं, जो निर्देशिका सेवाओं, सुरक्षा और समवर्ती नियंत्रण जैसे पहलुओं का समर्थन करते हैं।
* एक क्लाइंट या सर्वर जिसमें एक पूर्ण प्रसंस्करण वातावरण को प्रयुक्त करने के लिए आवश्यक सभी प्रबंधक सम्मिलित हैं, जो निर्देशिका सेवाओं, सुरक्षा और समवर्ती नियंत्रण जैसे स्वरूपों का समर्थन करते हैं।


डीडीएम का प्रारंभिक संस्करण वितरित फ़ाइल सेवाओं को परिभाषित करता है। इसे बाद में [[जिला ग्रामीण विकास एजेंसी]] (डीआरडीए) की नींव के रूप में विस्तारित किया गया।
डीडीएम का प्रारंभिक संस्करण वितरित फ़ाइल सेवाओं को परिभाषित करता है। इसे बाद में [[जिला ग्रामीण विकास एजेंसी|वितरित संबंधपरक डेटाबेस संरचना]] (डीआरडीए) की नींव के रूप में विस्तारित किया गया।


== डिजाइन पैटर्न ==
== डिजाइन पैटर्न ==
वस्तु-उन्मुख डिजाइन की चुनौतियों को कई तरीकों से संबोधित किया जाता है। सबसे सामान्य डिजाइन पैटर्न (पुस्तक) के रूप में जाना जाता है। गामा एट अल द्वारा संहिताबद्ध डिजाइन पैटर्न। अधिक मोटे तौर पर, शब्द [[डिजाइन पैटर्न (कंप्यूटर विज्ञान)]] का उपयोग किसी भी सामान्य, दोहराए जाने योग्य, समाधान पैटर्न को संदर्भित करने के लिए किया जा सकता है। सॉफ्टवेयर डिजाइन में। इनमें से कुछ सामान्य रूप से होने वाली समस्याओं के निहितार्थ और समाधान विशेष रूप से वस्तु-उन्मुख विकास के लिए हैं।
वस्तु-उन्मुख डिजाइन की चुनौतियों को कई तरीकों से संबोधित किया जाता है। सबसे सामान्य डिजाइन पैटर्न गामा एट अल द्वारा संहिताबद्ध डिजाइन पैटर्न के रूप में जाना जाता है।। अधिक सामान्य रूप से, शब्द डिजाइन पैटर्न" शब्द का उपयोग सॉफ्टवेयर डिजाइन में सामान्य रूप से होने वाली समस्या के लिए किसी भी सामान्य, दोहराने योग्य, समाधान पैटर्न को संदर्भित करने के लिए किया जा सकता है। इनमें से कुछ सामान्य रूप से होने वाली समस्याओं के निहितार्थ और समाधान विशेष रूप से वस्तु-उन्मुख विकास के लिए हैं।


=== इनहेरिटेंस और गतिविधि उपप्रकार ===
=== इनहेरिटेंस और गतिविधि सबटाइपिंग ===
{{See also|Object-oriented design}}<!-- not "further" because that article is mostly blather and does not even mention this -->
{{See also|वस्तु उन्मुख डिजाइन}}
यह मानने के लिए सहज है कि इनहेरिटेंस एक प्रोग्राम सेमेन्टिक्स बनाता है, एक संबंध है, और इस प्रकार यह अनुमान लगाने के लिए कि उपवर्गों से तत्काल वस्तुओं को हमेशा सुपरक्लास से तत्काल के अतिरिक्त सुरक्षित रूप से उपयोग किया जा सकता है। यह अंतर्ज्ञान दुर्भाग्य से अधिकांश वस्तु-उन्मुख प्रोग्रामिंग भाषाओं में गलत है, विशेष रूप से उन सभी में जो परस्पर वस्तुओं की स्वीकृति देते हैं। [[उपप्रकार बहुरूपता]] जैसा कि वस्तु-उन्मुख प्रोग्रामिंग भाषाओं में प्रकार चेकर द्वारा लागू किया गया है (परिवर्तनीय वस्तुओं के साथ) किसी भी संदर्भ में व्यवहारिक उपप्रकार की गारंटी नहीं दे सकता है। [[व्यवहार उपप्रकार|गतिविधि उपप्रकार]] सामान्य रूप से अनिर्णीत है, इसलिए इसे एक प्रोग्राम (संकलक) द्वारा लागू नहीं किया जा सकता है। क्लास या ऑब्जेक्ट पदानुक्रम को सावधानीपूर्वक डिज़ाइन किया जाना चाहिए, संभावित गलत उपयोगों पर विचार करते हुए जिन्हें सिंटैक्टिक रूप से नहीं पहचाना जा सकता है। इस मुद्दे को [[लिस्कोव प्रतिस्थापन सिद्धांत]] के रूप में जाना जाता है।


=== चार डिजाइन पैटर्न का गिरोह ===
यह मानने के लिए सहज ज्ञान युक्त है कि इनहेरिटेंस एक प्रोग्राम सेमेन्टिक्स, संबंध बनाता है, और इस प्रकार यह अनुमान लगाने के लिए कि सबक्लास से दृष्टांतिकृत वस्तुओं को हमेशा सुपरक्लास से तत्काल के अतिरिक्त सुरक्षित रूप से उपयोग किया जा सकता है। यह अंतर्ज्ञान दुर्भाग्य से अधिकांश वस्तु-उन्मुख प्रोग्रामिंग भाषाओं में गलत है, विशेष रूप से उन सभी में जो परस्पर वस्तुओं की स्वीकृति देते हैं। [[उपप्रकार बहुरूपता|सबटाइपिंग बहुरूपता]] जैसा कि वस्तु-उन्मुख प्रोग्रामिंग भाषाओं में प्रकार चेकर द्वारा प्रयुक्त किया गया है (परिवर्तनीय वस्तुओं के साथ) किसी भी संदर्भ में व्यवहारिक सबटाइपिंग की गारंटी नहीं दे सकता है। [[व्यवहार उपप्रकार|गतिविधि सबटाइपिंग]] सामान्य रूप से अनिर्णीत है, इसलिए इसे एक प्रोग्राम (संकलक) द्वारा प्रयुक्त नहीं किया जा सकता है। क्लास या ऑब्जेक्ट पदानुक्रम को सावधानीपूर्वक डिज़ाइन किया जाना चाहिए, संभावित गलत उपयोगों पर विचार करते हुए जिन्हें सिंटैक्टिक रूप से नहीं पहचाना जा सकता है। इस समस्या को [[लिस्कोव प्रतिस्थापन सिद्धांत]] के रूप में जाना जाता है।
{{Main|Design pattern (computer science)}}
 
डिजाइन पैटर्न (पुस्तक) | डिजाइन पैटर्न: पुन: प्रयोज्य वस्तु-उन्मुख सॉफ्टवेयर के तत्व 1994 में [[एरिक गामा]], [[रिचर्ड हेल्म]], [[राल्फ जॉनसन (कंप्यूटर वैज्ञानिक)]], और [[जॉन व्लिससाइड्स]] द्वारा प्रकाशित एक प्रभावशाली पुस्तक है, जिसे प्रायः मजाक में चार की गिरोह के रूप में संदर्भित किया जाता है। . वस्तु-उन्मुख प्रोग्रामिंग की क्षमताओं और नुकसान की खोज के साथ-साथ, यह 23 सामान्य प्रोग्रामिंग समस्याओं और उन्हें हल करने [[मुखौटा पैटर्न]] का वर्णन करता है।
=== चार डिजाइन पैटर्न का समूह ===
अप्रैल 2007 तक, पुस्तक अपने 36वें मुद्रण में थी।
{{Main|डिजाइन पैटर्न (कंप्यूटर विज्ञान)}}
डिजाइन पैटर्न (पुस्तक) | डिजाइन पैटर्न: पुन: प्रयोज्य वस्तु-उन्मुख सॉफ्टवेयर के तत्व 1994 में [[एरिक गामा]], [[रिचर्ड हेल्म]], [[राल्फ जॉनसन (कंप्यूटर वैज्ञानिक)]], और [[जॉन व्लिससाइड्स]] द्वारा प्रकाशित एक प्रभावशाली पुस्तक है, जिसे प्रायः विनोदपूर्वक में गैंग ऑफ़ फोर" के रूप में संदर्भित किया जाता है। वस्तु-उन्मुख प्रोग्रामिंग की क्षमताओं और नुकसान की खोज के साथ-साथ, यह 23 सामान्य प्रोग्रामिंग समस्याओं और उन्हें संशोधित करने [[मुखौटा पैटर्न|पैटर्न]] का वर्णन करता है। अप्रैल 2007 तक, पुस्तक अपने 36वें मुद्रण में थी।


पुस्तक निम्नलिखित पैटर्न का वर्णन करती है:
पुस्तक निम्नलिखित पैटर्न का वर्णन करती है:
* क्रिएशनल पैटर्न (5): [[फैक्टरी विधि पैटर्न]], [[सार कारखाना पैटर्न]], [[सिंगलटन पैटर्न]], [[बिल्डर पैटर्न]], [[प्रोटोटाइप पैटर्न]]
* रचनात्मक पैटर्न (5): [[फैक्टरी विधि पैटर्न]], [[सार कारखाना पैटर्न]], [[सिंगलटन पैटर्न]], [[बिल्डर पैटर्न]], [[प्रोटोटाइप पैटर्न]]
* [[सं[[रचनात्मक पैटर्न]]]] (7): [[एडेप्टर पैटर्न]], [[ब्रिज पैटर्न]], [[समग्र पैटर्न]], [[डेकोरेटर पैटर्न]], फेकाडे पैटर्न, [[फ्लाईवेट पैटर्न]], [[प्रॉक्सी पैटर्न]]
* सं[[रचनात्मक पैटर्न]] (7): [[एडेप्टर पैटर्न]], [[ब्रिज पैटर्न]], [[समग्र पैटर्न]], [[डेकोरेटर पैटर्न]], फेकाडे पैटर्न, [[फ्लाईवेट पैटर्न]], [[प्रॉक्सी पैटर्न]]
* [[व्यवहार पैटर्न|गतिविधि पैटर्न]] (11): [[चेन-ऑफ-जिम्मेदारी पैटर्न]], [[कमांड पैटर्न]], [[दुभाषिया पैटर्न]], [[इटरेटर पैटर्न]], [[मध्यस्थ पैटर्न]], [[स्मृति चिन्ह पैटर्न|मेमोरी चिन्ह पैटर्न]], [[पर्यवेक्षक पैटर्न]], [[राज्य पैटर्न]], [[रणनीति पैटर्न]], [[टेम्पलेट विधि पैटर्न]], [[विज़िटर पैटर्न]]
* [[व्यवहार पैटर्न|गतिविधि पैटर्न]] (11): [[चेन-ऑफ-जिम्मेदारी पैटर्न|चेन-ऑफ़-रिस्पॉन्सिबिलिटी पैटर्न]], [[कमांड पैटर्न]], [[दुभाषिया पैटर्न]], [[इटरेटर पैटर्न]], [[मध्यस्थ पैटर्न]], [[स्मृति चिन्ह पैटर्न|मेमोरी चिन्ह पैटर्न]], [[पर्यवेक्षक पैटर्न]], [[राज्य पैटर्न|स्थिति पैटर्न]], [[रणनीति पैटर्न]], [[टेम्पलेट विधि पैटर्न]], [[विज़िटर पैटर्न]]


=== ऑब्जेक्ट-ओरिएंटेशन और डेटाबेस ===
=== ऑब्जेक्ट-ओरिएंटेशन और डेटाबेस ===
{{Main|Object-relational impedance mismatch|Object-relational mapping|Object database}}
{{Main|वस्तु-संबंधपरक प्रतिबाधा बेमेल, वस्तु-संबंधपरक मानचित्रण और वस्तु डेटाबेस}}
वस्तु-उन्मुख प्रोग्रामिंग और [[संबंधपरक डेटाबेस प्रबंधन प्रणाली]] (RDBMS) दोनों सॉफ्टवेयर में बेहद सामान्य हैं {{As of|2006|alt=today}}. चूंकि संबंधपरक डेटाबेस वस्तुओं को सीधे स्टोर नहीं करते हैं (हालांकि कुछ आरडीबीएमएस में इसका अनुमान लगाने के लिए वस्तु-उन्मुख विशेषताएं हैं), दो दुनियाओं को पाटने की एक सामान्य आवश्यकता है। [[संबंध का डेटाबेस]] के साथ वस्तु-उन्मुख प्रोग्रामिंग एक्सेस और डेटा पैटर्न को पाटने की समस्या को [[वस्तु-संबंधपरक प्रतिबाधा बेमेल]] के रूप में जाना जाता है। इस समस्या से निपटने के लिए कई तरीके हैं, लेकिन बिना नुकसान के कोई सामान्य समाधान नहीं है।<ref name="RDMDBobjectmis">{{Cite web| first = Ted| last = Neward| title = The Vietnam of Computer Science| date = 26 June 2006| access-date = 2 June 2010| publisher = Interoperability Happens| url = http://blogs.tedneward.com/2006/06/26/The+Vietnam+Of+Computer+Science.aspx| archive-url = https://web.archive.org/web/20060704030226/http://blogs.tedneward.com/2006/06/26/The+Vietnam+Of+Computer+Science.aspx| archive-date = 4 July 2006| url-status = dead| df = dmy-all}}</ref> सबसे सामान्य दृष्टिकोणों में से एक [[ऑब्जेक्ट-रिलेशनल मैपिंग]] है, जैसा कि [[एकीकृत विकास पर्यावरण]] भाषाओं जैसे [[विजुअल फॉक्सप्रो]] और लाइब्रेरी जैसे [[जावा डेटा ऑब्जेक्ट्स]] और [[रूबी ऑन रेल्स]] 'एक्टिव रिकॉर्ड में पाया जाता है।
वस्तु-उन्मुख प्रोग्रामिंग और [[संबंधपरक डेटाबेस प्रबंधन प्रणाली]] (आरडीबीएमएस) दोनों {{As of|2006|alt=वर्तमान}} सॉफ्टवेयर में अधिकतम सामान्य हैं . चूंकि संबंधपरक डेटाबेस वस्तुओं को प्रत्यक्ष रूप से संग्रहित नहीं करते हैं (हालांकि कुछ आरडीबीएमएस में इसका अनुमान लगाने के लिए वस्तु-उन्मुख विशेषताएं हैं), विश्व को संपर्क की एक सामान्य आवश्यकता है। [[संबंध का डेटाबेस]] के साथ वस्तु-उन्मुख प्रोग्रामिंग एक्सेस और डेटा पैटर्न को संपर्क की समस्या को [[वस्तु-संबंधपरक प्रतिबाधा बेमेल]] के रूप में जाना जाता है। इस समस्या से निपटने के लिए कई तरीके हैं, लेकिन बिना नुकसान के कोई सामान्य समाधान नहीं है।<ref name="RDMDBobjectmis">{{Cite web| first = Ted| last = Neward| title = The Vietnam of Computer Science| date = 26 June 2006| access-date = 2 June 2010| publisher = Interoperability Happens| url = http://blogs.tedneward.com/2006/06/26/The+Vietnam+Of+Computer+Science.aspx| archive-url = https://web.archive.org/web/20060704030226/http://blogs.tedneward.com/2006/06/26/The+Vietnam+Of+Computer+Science.aspx| archive-date = 4 July 2006| url-status = dead| df = dmy-all}}</ref> सबसे सामान्य दृष्टिकोणों में से एक [[ऑब्जेक्ट-रिलेशनल मैपिंग]] है, जैसा कि [[एकीकृत विकास पर्यावरण]] भाषाओं जैसे [[विजुअल फॉक्सप्रो]] और पुस्तकालय जैसे [[जावा डेटा ऑब्जेक्ट्स]] और [[रूबी ऑन रेल्स]] 'सक्रिय रिकॉर्ड में पाया जाता है।


ऐसे [[वस्तु डेटाबेस]] भी हैं जिनका उपयोग संबंधपरक डेटाबेस प्रबंधन प्रणाली को बदलने के लिए किया जा सकता है, लेकिन ये संबंधपरक डेटाबेस प्रबंधन प्रणाली की तरह तकनीकी और व्यावसायिक रूप से सफल नहीं रहे हैं।
ऐसे [[वस्तु डेटाबेस]] भी हैं जिनका उपयोग संबंधपरक डेटाबेस प्रबंधन प्रणाली को परिवर्तित करने के लिए किया जा सकता है, लेकिन ये संबंधपरक डेटाबेस प्रबंधन प्रणाली की तरह तकनीकी और व्यावसायिक रूप से सफल नहीं रहे हैं।


=== वास्तविक विश्व मॉडलिंग और रिश्ते ===
=== वास्तविक विश्व मॉडलिंग और रिश्ते ===
वस्तु-उन्मुख प्रोग्रामिंग का उपयोग वास्तविक विश्व की वस्तुओं और प्रक्रियाओं को डिजिटल समकक्षों के साथ जोड़ने के लिए किया जा सकता है। हालांकि, हर कोई इस बात से सहमत नहीं है कि वस्तु-उन्मुख प्रोग्रामिंग प्रत्यक्ष वास्तविक-विश्व मानचित्रण की सुविधा देता है (#आलोचना अनुभाग देखें) या यह कि वास्तविक-विश्व मानचित्रण एक योग्य लक्ष्य भी है; बर्ट्रेंड मेयर वस्तु-उन्मुख सॉफ्टवेयर कंस्ट्रक्शन में तर्क देते हैं<ref name="Meyer230">Meyer, Second Edition, p. 230</ref> कि एक प्रोग्राम विश्व का मॉडल नहीं बल्कि विश्व के किसी हिस्से का मॉडल है; वास्तविकता एक चचेरी बहन है जिसे दो बार हटा दिया गया है। उसी समय, वस्तु-उन्मुख प्रोग्रामिंग की कुछ प्रमुख सीमाएँ नोट की गई हैं।<ref>M.Trofimov, ''OOOP – The Third "O" Solution: Open OOP.'' First Class, [[Object Management Group|OMG]], 1993, Vol. 3, issue 3, p.14.</ref>
वस्तु-उन्मुख प्रोग्रामिंग का उपयोग वास्तविक विश्व की वस्तुओं और प्रक्रियाओं को डिजिटल समकक्षों के साथ जोड़ने के लिए किया जा सकता है। हालांकि, हर कोई इस बात से सहमत नहीं है कि वस्तु-उन्मुख प्रोग्रामिंग प्रत्यक्ष वास्तविक-विश्व मानचित्रण की सुविधा देता है (आलोचना अनुभाग देखें) या यह कि वास्तविक-विश्व मानचित्रण एक योग्य लक्ष्य भी है; बर्ट्रेंड मेयर वस्तु-उन्मुख सॉफ्टवेयर निर्माण में तर्क देते हैं<ref name="Meyer230">Meyer, Second Edition, p. 230</ref> कि एक प्रोग्राम विश्व का मॉडल नहीं बल्कि विश्व के किसी हिस्से का मॉडल है; वास्तविकता एक कजिन है जिसे दो बार हटा दिया गया है। उसी समय, वस्तु-उन्मुख प्रोग्रामिंग की कुछ प्रमुख सीमाएँ उल्लेख की गई हैं।<ref>M.Trofimov, ''OOOP – The Third "O" Solution: Open OOP.'' First Class, [[Object Management Group|OMG]], 1993, Vol. 3, issue 3, p.14.</ref> उदाहरण के लिए, वस्तु-उन्मुख प्रोग्रामिंग की इनहेरिटेंस (वस्तु-उन्मुख प्रोग्रामिंग) की अवधारणा का उपयोग करके वृत्त-दीर्घवृत्त समस्या समस्या को संभालना कठिन है।


उदाहरण के लिए, वस्तु-उन्मुख प्रोग्रामिंग की इनहेरिटेंस (वस्तु-उन्मुख प्रोग्रामिंग) की अवधारणा का उपयोग करके सर्कल-एलीप्से समस्या को संभालना मुश्किल है।
हालांकि, निकलॉस विर्थ (जिन्होंने विर्थ के नियम के रूप में पहचानी जाने वाले कथन को लोकप्रिय बनाया और हार्डवेयर की तुलना में सॉफ्टवेयर तेजी से मंद हो रहा है) ने अपने पत्र में वस्तु-उन्मुख प्रोग्रामिंग के बारे में कहा, <nowiki>''</nowiki>लुकिंग ग्लास के माध्यम से अच्छे विचार<nowiki>''</nowiki>, यह पैराडिग्म 'वास्तविक विश्व में' प्रणालियों की संरचना को ध्यान से दर्शाता है, और इसलिए यह जटिल गतिविधि के साथ मॉडल जटिल प्रणालियों के लिए उपयुक्त है<ref>{{cite journal |title=Good Ideas, Through the Looking Glass |journal=[[Computer (magazine)|Computer]] |year=2006 |last=Wirth |first=Nicklaus |author-link=Niklaus Wirth |volume=39 |issue=1 |pages=28–39 |url=https://pdfs.semanticscholar.org/10bd/dc49b85196aaa6715dd46843d9dcffa38358.pdf |archive-url=https://web.archive.org/web/20161012215755/https://pdfs.semanticscholar.org/10bd/dc49b85196aaa6715dd46843d9dcffa38358.pdf |url-status=dead |archive-date=12 October 2016 |access-date=2 October 2016 |doi=10.1109/mc.2006.20|s2cid=6582369 }}</ref> (विपरीत केआईएसएस सिद्धांत)


हालांकि, निकलॉस विर्थ (जिन्होंने विर्थ के नियम के रूप में जानी जाने वाली कहावत को लोकप्रिय बनाया: हार्डवेयर की तुलना में सॉफ्टवेयर तेजी से धीमा हो रहा है) ने अपने पेपर में वस्तु-उन्मुख प्रोग्रामिंग के बारे में कहा, लुकिंग ग्लास के माध्यम से अच्छे विचार, यह प्रतिमान बारीकी से प्रणाली की संरचना को दर्शाता है 'में वास्तविक विश्व', और इसलिए यह जटिल व्यवहारों के साथ मॉडल जटिल प्रणालियों के लिए उपयुक्त है<ref>{{cite journal |title=Good Ideas, Through the Looking Glass |journal=[[Computer (magazine)|Computer]] |year=2006 |last=Wirth |first=Nicklaus |author-link=Niklaus Wirth |volume=39 |issue=1 |pages=28–39 |url=https://pdfs.semanticscholar.org/10bd/dc49b85196aaa6715dd46843d9dcffa38358.pdf |archive-url=https://web.archive.org/web/20161012215755/https://pdfs.semanticscholar.org/10bd/dc49b85196aaa6715dd46843d9dcffa38358.pdf |url-status=dead |archive-date=12 October 2016 |access-date=2 October 2016 |doi=10.1109/mc.2006.20|s2cid=6582369 }}</ref> (विपरीत KISS सिद्धांत)।
[[स्टीव येगे]] और अन्य ने उल्लेख किया कि प्राकृतिक भाषाओं में फंक्शन (विधियों/[[क्रिया]]ओं) से पहले वस्तुओ (वस्तुओं/[[संज्ञा]]ओं) को दृढ़ से प्राथमिकता देने के वस्तु-उन्मुख प्रोग्रामिंग दृष्टिकोण की कमी है।<ref name="executioniKoN">{{Cite web| first = Steve| last=Yegge |title = Execution in the Kingdom of Nouns| date=30 March 2006|access-date=3 July 2010| publisher = steve-yegge.blogspot.com| url=http://steve-yegge.blogspot.com/2006/03/execution-in-kingdom-of-nouns.html}}</ref> यह समस्या वस्तु-उन्मुख प्रोग्रामिंग को प्रक्रियात्मक प्रोग्रामिंग की तुलना में अधिक जटिल समाधान करने का कारण बन सकती है।<ref name="executioniKoN2">{{Cite web| first = Timothy| last= Boronczyk |title = What's Wrong with OOP| date=11 June 2009|access-date=3 July 2010| publisher = zaemis.blogspot.com| url=http://zaemis.blogspot.com/2009/06/whats-wrong-with-oop.html}}</ref>


[[स्टीव येगे]] और अन्य ने नोट किया कि प्राकृतिक भाषाओं में फंक्शन (विधियों/[[क्रिया]]ओं) से पहले चीजों (वस्तुओं/[[संज्ञा]]ओं) को सख्ती से प्राथमिकता देने के वस्तु-उन्मुख प्रोग्रामिंग दृष्टिकोण की कमी है।<ref name="executioniKoN">{{Cite web| first = Steve| last=Yegge |title = Execution in the Kingdom of Nouns| date=30 March 2006|access-date=3 July 2010| publisher = steve-yegge.blogspot.com| url=http://steve-yegge.blogspot.com/2006/03/execution-in-kingdom-of-nouns.html}}</ref> यह समस्या वस्तु-उन्मुख प्रोग्रामिंग को प्रक्रियात्मक प्रोग्रामिंग की तुलना में अधिक जटिल समाधान भुगतने का कारण बन सकती है।<ref name="executioniKoN2">{{Cite web| first = Timothy| last= Boronczyk |title = What's Wrong with OOP| date=11 June 2009|access-date=3 July 2010| publisher = zaemis.blogspot.com| url=http://zaemis.blogspot.com/2009/06/whats-wrong-with-oop.html}}</ref>






=== वस्तु-उन्मुख प्रोग्रामिंग और नियंत्रण प्रवाह ===
=== वस्तु-उन्मुख प्रोग्रामिंग और नियंत्रण संचालन ===
वस्तु-उन्मुख प्रोग्रामिंग को कोड के पुन: उपयोग और स्रोत कोड के सॉफ़्टवेयर संरक्षण को बढ़ाने के लिए विकसित किया गया था।<ref name="realisticcodereuse">{{Cite web| first = Scott| last= Ambler| title = A Realistic Look at Object-Oriented Reuse| date=1 January 1998| access-date=4 July 2010| publisher = drdobbs.com| url=http://www.drdobbs.com/184415594}}</ref> नियंत्रण प्रवाह के पारदर्शी प्रतिनिधित्व की कोई प्राथमिकता नहीं थी और इसका मतलब एक संकलक द्वारा नियंत्रित किया जाना था। समानांतर हार्डवेयर और थ्रेड (कंप्यूटर विज्ञान) की बढ़ती प्रासंगिकता के साथ, पारदर्शी नियंत्रण प्रवाह विकसित करना अधिक महत्वपूर्ण हो जाता है, वस्तु-उन्मुख प्रोग्रामिंग के साथ कुछ हासिल करना कठिन होता है।<ref name="flaws">{{Cite web| first = Asaf| last= Shelly |title = Flaws of Object Oriented Modeling| date=22 August 2008|access-date=4 July 2010| publisher = Intel Software Network| url=http://software.intel.com/en-us/blogs/2008/08/22/flaws-of-object-oriented-modeling/}}</ref><ref name="multithreadingisaverb">{{Cite web| first = Justin| last = James| title = Multithreading is a verb not a noun| date = 1 October 2007| access-date = 4 July 2010| publisher = techrepublic.com| url = http://blogs.techrepublic.com.com/programming-and-development/?p=518| archive-url = https://web.archive.org/web/20071010105117/http://blogs.techrepublic.com.com/programming-and-development/?p=518| archive-date = 10 October 2007| url-status = dead| df = dmy-all}}</ref><ref name="multicore">{{Cite web| first = Asaf| last= Shelly| title = HOW TO: Multicore Programming (Multiprocessing) Visual C++ Class Design Guidelines, Member Functions| date=22 August 2008| access-date=4 July 2010| publisher = support.microsoft.com| url=http://support.microsoft.com/?scid=kb%3Ben-us%3B558117}}</ref><ref>{{cite web|url=http://existentialtype.wordpress.com/2011/04/17/some-advice-on-teaching-fp/|title=Some thoughts on teaching FP|author=Robert Harper |publisher=Existential Type Blog|access-date=5 December 2011|date=17 April 2011|author-link=Robert Harper (computer scientist)}}</ref>
वस्तु-उन्मुख प्रोग्रामिंग को कोड के पुन: उपयोग और स्रोत कोड के सॉफ़्टवेयर संरक्षण को बढ़ाने के लिए विकसित किया गया था।<ref name="realisticcodereuse">{{Cite web| first = Scott| last= Ambler| title = A Realistic Look at Object-Oriented Reuse| date=1 January 1998| access-date=4 July 2010| publisher = drdobbs.com| url=http://www.drdobbs.com/184415594}}</ref> नियंत्रण संचालन के पारदर्शी प्रतिनिधित्व की कोई प्राथमिकता नहीं थी और इसका तात्पर्य एक संकलक द्वारा नियंत्रित किया जाना था। समानांतर हार्डवेयर और बहुप्रचारित कोडिंग, (कंप्यूटर विज्ञान) की बढ़ती प्रासंगिकता के साथ, पारदर्शी नियंत्रण संचालन विकसित करना अधिक महत्वपूर्ण हो जाता है, वस्तु-उन्मुख प्रोग्रामिंग के साथ कुछ प्राप्त करना कठिन होता है।<ref name="flaws">{{Cite web| first = Asaf| last= Shelly |title = Flaws of Object Oriented Modeling| date=22 August 2008|access-date=4 July 2010| publisher = Intel Software Network| url=http://software.intel.com/en-us/blogs/2008/08/22/flaws-of-object-oriented-modeling/}}</ref><ref name="multithreadingisaverb">{{Cite web| first = Justin| last = James| title = Multithreading is a verb not a noun| date = 1 October 2007| access-date = 4 July 2010| publisher = techrepublic.com| url = http://blogs.techrepublic.com.com/programming-and-development/?p=518| archive-url = https://web.archive.org/web/20071010105117/http://blogs.techrepublic.com.com/programming-and-development/?p=518| archive-date = 10 October 2007| url-status = dead| df = dmy-all}}</ref><ref name="multicore">{{Cite web| first = Asaf| last= Shelly| title = HOW TO: Multicore Programming (Multiprocessing) Visual C++ Class Design Guidelines, Member Functions| date=22 August 2008| access-date=4 July 2010| publisher = support.microsoft.com| url=http://support.microsoft.com/?scid=kb%3Ben-us%3B558117}}</ref><ref>{{cite web|url=http://existentialtype.wordpress.com/2011/04/17/some-advice-on-teaching-fp/|title=Some thoughts on teaching FP|author=Robert Harper |publisher=Existential Type Blog|access-date=5 December 2011|date=17 April 2011|author-link=Robert Harper (computer scientist)}}</ref>




=== उत्तरदायित्व- बनाम डेटा-संचालित डिज़ाइन ===
=== उत्तरदायित्व- बनाम डेटा-संचालित डिज़ाइन ===
उत्तरदायित्व-संचालित डिजाइन एक अनुबंध के संदर्भ में क्लासेस को परिभाषित करता है, अर्थात, एक क्लास को एक जिम्मेदारी और उसके द्वारा साझा की जाने वाली जानकारी के आसपास परिभाषित किया जाना चाहिए। यह [[डेटा-संचालित प्रोग्रामिंग]] के साथ Wirfs-Brock और Wilkerson द्वारा विपरीत है। डेटा-संचालित डिज़ाइन, जहां क्लास को डेटा-संरचनाओं के आसपास परिभाषित किया जाना चाहिए। लेखकों का मानना ​​है कि जिम्मेदारी से संचालित डिजाइन बेहतर है।
उत्तरदायित्व-संचालित डिजाइन एक अनुबंध के संदर्भ में क्लासेस को परिभाषित करता है, अर्थात, एक क्लास को एक उत्तरदायित्व और उसके द्वारा साझा की जाने वाली जानकारी के आसपास परिभाषित किया जाना चाहिए। यह [[डेटा-संचालित प्रोग्रामिंग]] के साथ वाइर्फ्स-ब्रॉक और विल्करसन द्वारा विपरीत है। डेटा-संचालित डिज़ाइन, जहां क्लास को डेटा-संरचनाओं के आसपास परिभाषित किया जाना चाहिए। लेखकों का मानना ​​है कि उत्तरदायित्व से संचालित डिजाइन अपेक्षाकृत अधिक अच्छा है।


===ठोस और GRASP दिशानिर्देश===
===एसओएलआईडी और जीआरएएसपी दिशानिर्देश===
SOLID (वस्तु-उन्मुख डिज़ाइन) माइकल फेदर्स द्वारा आविष्कार किया गया एक स्मरक है जो पाँच सॉफ्टवेयर इंजीनियरिंग डिज़ाइन सिद्धांतों को बताता है:
एसओएलआईडी (वस्तु-उन्मुख डिज़ाइन) माइकल फेदर्स द्वारा आविष्कार किया गया एक मनेमोनिक (मेमोरी सहायक) है जो पाँच सॉफ्टवेयर इंजीनियरिंग डिज़ाइन सिद्धांतों को बताता है:
* [[एकल जिम्मेदारी सिद्धांत]]
* [[एकल जिम्मेदारी सिद्धांत|एकल उत्तरदायित्व का सिद्धांत]]
* खुला / बंद सिद्धांत
* ओपन-क्लोज सिद्धांत
* लिस्कोव प्रतिस्थापन सिद्धांत
* लिस्कोव प्रतिस्थापन सिद्धांत
* [[इंटरफ़ेस पृथक्करण सिद्धांत]]
* [[इंटरफ़ेस पृथक्करण सिद्धांत]]
* [[निर्भरता उलटा सिद्धांत]]
* [[निर्भरता उलटा सिद्धांत|निर्भरता व्युत्क्रम का सिद्धांत]]


[[GRASP (ऑब्जेक्ट-ओरिएंटेड डिज़ाइन)|GRASP (वस्तु-उन्मुख डिज़ाइन)]] (जनरल रिस्पॉन्सिबिलिटी असाइनमेंट सॉफ़्टवेयर पैटर्न) [[क्रेग लर्मन]] द्वारा समर्थित दिशानिर्देशों का एक और सेट है।
[[GRASP (ऑब्जेक्ट-ओरिएंटेड डिज़ाइन)|जीआरएएसपी (वस्तु-उन्मुख डिज़ाइन)]] (सामान्य अधीन समनुदेशन सॉफ्टवेयर पैटर्न) [[क्रेग लर्मन]] द्वारा समर्थित दिशानिर्देशों का एक अन्य समूह है।


== आलोचना ==
== आलोचना ==
वस्तु-उन्मुख प्रोग्रामिंग प्रतिमान की कई कारणों से आलोचना की गई है, जिसमें पुन: प्रयोज्यता और मॉड्यूलरिटी के अपने घोषित लक्ष्यों को पूरा नहीं करना सम्मिलित है,<ref name="badprop"/><ref name="armstrongjoe"/>और अन्य महत्वपूर्ण पहलुओं (गणना/एल्गोरिदम) की कीमत पर सॉफ्टवेयर डिजाइन और मॉडलिंग (डेटा/ऑब्जेक्ट्स) के एक पहलू पर अधिक जोर देने के लिए।<ref name="stepanov"/><ref name="hickey"/>
वस्तु-उन्मुख प्रोग्रामिंग पैराडिग्म की कई कारणों से आलोचना की गई है, जिसमें पुन: प्रयोज्यता और मॉड्यूलता के अपने घोषित लक्ष्यों को पूरा नहीं करना,<ref name="badprop"/><ref name="armstrongjoe"/> और अन्य महत्वपूर्ण स्वरूपों (गणना/एल्गोरिदम) की कीमत पर सॉफ्टवेयर डिजाइन और मॉडलिंग (डेटा/ऑब्जेक्ट्स) के एक स्वरूप पर अधिक जोर देने के लिए सम्मिलित है।<ref name="stepanov"/><ref name="hickey"/>


[[Luca Cardelli]] ने दावा किया है कि वस्तु-उन्मुख प्रोग्रामिंग कोड प्रक्रियात्मक कोड की तुलना में आंतरिक रूप से कम कुशल है, वस्तु-उन्मुख प्रोग्रामिंग को संकलित करने में अधिक समय लग सकता है, और यह कि वस्तु-उन्मुख प्रोग्रामिंग भाषाओं में क्लास विस्तार और संशोधन के संबंध में बेहद खराब मॉड्यूलरिटी गुण हैं, और यह बेहद जटिल हैं।<ref name="badprop">{{Cite journal| first=Luca| last=Cardelli|title=Bad Engineering Properties of Object-Oriented Languages |url=http://lucacardelli.name/Papers/BadPropertiesOfOO.html| year=1996| access-date=21 April 2010| doi=10.1145/242224.242415| journal = ACM Comput. Surv.| volume=28| issn = 0360-0300| pages = 150–es| author-link=Luca Cardelli| issue=4es| s2cid=12105785}}</ref> उत्तरार्द्ध बिंदु [[जो आर्मस्ट्रांग (प्रोग्रामिंग)]] द्वारा दोहराया गया है, जो एरलांग (प्रोग्रामिंग भाषा) के प्रमुख आविष्कारक हैं, जिन्हें यह कहते हुए उद्धृत किया गया है:<ref name="armstrongjoe">Armstrong, Joe. In ''Coders at Work: Reflections on the Craft of Programming.'' Peter Seibel, ed. [http://www.codersatwork.com/ Codersatwork.com] {{Webarchive|url=https://web.archive.org/web/20100305165150/http://www.codersatwork.com/ |date=5 March 2010 }}, Accessed 13 November 2009.</ref>
[[Luca Cardelli|लुका कार्डेली]] ने दावा किया है कि वस्तु-उन्मुख प्रोग्रामिंग कोड प्रक्रियात्मक कोड की तुलना में आंतरिक रूप से कम कुशल है, वस्तु-उन्मुख प्रोग्रामिंग को संकलित करने में अधिक समय लग सकता है, और यह कि वस्तु-उन्मुख प्रोग्रामिंग भाषाओं में क्लास विस्तार और संशोधन के संबंध में अधिकतम दोषपूर्ण मॉड्यूलता गुण हैं, और यह अधिकतम जटिल हैं।<ref name="badprop">{{Cite journal| first=Luca| last=Cardelli|title=Bad Engineering Properties of Object-Oriented Languages |url=http://lucacardelli.name/Papers/BadPropertiesOfOO.html| year=1996| access-date=21 April 2010| doi=10.1145/242224.242415| journal = ACM Comput. Surv.| volume=28| issn = 0360-0300| pages = 150–es| author-link=Luca Cardelli| issue=4es| s2cid=12105785}}</ref> और बाद वाले बिंदु [[जो आर्मस्ट्रांग (प्रोग्रामिंग)]] द्वारा दोहराया गया है, जो एरलांग (प्रोग्रामिंग भाषा) के प्रमुख आविष्कारक हैं, जिन्हें यह कहते हुए उद्धृत किया गया है:<ref name="armstrongjoe">Armstrong, Joe. In ''Coders at Work: Reflections on the Craft of Programming.'' Peter Seibel, ed. [http://www.codersatwork.com/ Codersatwork.com] {{Webarchive|url=https://web.archive.org/web/20100305165150/http://www.codersatwork.com/ |date=5 March 2010 }}, Accessed 13 November 2009.</ref>


{{quote|वस्तु-उन्मुख भाषाओं के साथ समस्या यह है कि उनके पास यह सब अंतर्निहित वातावरण है जो वे अपने साथ ले जाते हैं। आप एक केला चाहते थे लेकिन आपको जो मिला वह केला और पूरे जंगल मे सिर्फ एक गोरिल्ला पकड़े हुए था।}}
{{quote|वस्तु-उन्मुख भाषाओं के साथ समस्या यह है कि उनके पास यह सब अंतर्निहित वातावरण है जो वे अपने साथ ले जाते हैं। आप एक केला चाहते थे लेकिन आपको जो मिला वह केला और पूरे जंगल मे सिर्फ एक गोरिल्ला पकड़े हुए था।}}
पोटोक एट अल द्वारा एक अध्ययन। वस्तु-उन्मुख प्रोग्रामिंग और प्रक्रियात्मक दृष्टिकोण के बीच उत्पादकता में कोई महत्वपूर्ण अंतर नहीं दिखाया है।<ref>{{Cite journal| url=http://www.csm.ornl.gov/~v8q/Homepage/Papers%20Old/spetep-%20printable.pdf| title=Productivity Analysis of Object-Oriented Software Developed in a Commercial Environment| last=Potok| first=Thomas|author2=Mladen Vouk |author3=Andy Rindos |journal=Software: Practice and Experience | volume=29|issue=10|pages=833–847 |year=1999 |access-date=21 April 2010| doi=10.1002/(SICI)1097-024X(199908)29:10<833::AID-SPE258>3.0.CO;2-P| s2cid=57865731}}</ref>
पोटोक एट अल द्वारा एक अध्ययन वस्तु-उन्मुख प्रोग्रामिंग और प्रक्रियात्मक दृष्टिकोण के बीच उत्पादकता में कोई महत्वपूर्ण अंतर नहीं दिखाया है।<ref>{{Cite journal| url=http://www.csm.ornl.gov/~v8q/Homepage/Papers%20Old/spetep-%20printable.pdf| title=Productivity Analysis of Object-Oriented Software Developed in a Commercial Environment| last=Potok| first=Thomas|author2=Mladen Vouk |author3=Andy Rindos |journal=Software: Practice and Experience | volume=29|issue=10|pages=833–847 |year=1999 |access-date=21 April 2010| doi=10.1002/(SICI)1097-024X(199908)29:10<833::AID-SPE258>3.0.CO;2-P| s2cid=57865731}}</ref>  
क्रिस्टोफर जे. डेट ने कहा कि वस्तु-उन्मुख प्रोग्रामिंग की अन्य तकनीकों से महत्वपूर्ण तुलना, विशेष रूप से संबंधपरक, वस्तु-उन्मुख प्रोग्रामिंग की एक सहमत और कठोर परिभाषा की कमी के कारण कठिन है;<ref name="DatePage650">C. J. Date, Introduction to Database Systems, 6th-ed., Page 650</ref> हालाँकि, डेट और डार्वेन ने वस्तु-उन्मुख प्रोग्रामिंग पर एक सैद्धांतिक आधार प्रस्तावित किया है जो [[RDBMS]] का समर्थन करने के लिए वस्तु-उन्मुख प्रोग्रामिंग को एक प्रकार के अनुकूलन योग्य डेटा प्रकार के रूप में उपयोग करता है।<ref name="ThirdManifesto">C. J. Date, Hugh Darwen. ''Foundation for Future Database Systems: The Third Manifesto'' (2nd Edition)</ref>
 
एक लेख में लॉरेंस क्रुबनेर ने दावा किया कि अन्य भाषाओं (एलआईएसपी बोलियों, कार्यात्मक भाषाओं, आदि) की तुलना में वस्तु-उन्मुख प्रोग्रामिंग भाषाओं में कोई अनोखी ताकत नहीं है, और अनावश्यक जटिलता का भारी बोझ डालती है।<ref name="lawrence">{{Cite web| last=Krubner| first=Lawrence| title=Object Oriented Programming is an expensive disaster which must end| url=http://www.smashcompany.com/technology/object-oriented-programming-is-an-expensive-disaster-which-must-end| publisher=smashcompany.com| access-date=14 October 2014| archive-url=https://web.archive.org/web/20141014233854/http://www.smashcompany.com/technology/object-oriented-programming-is-an-expensive-disaster-which-must-end| archive-date=14 October 2014| url-status=dead}}</ref>
क्रिस्टोफर जे. डेट ने कहा कि वस्तु-उन्मुख प्रोग्रामिंग की अन्य तकनीकों से महत्वपूर्ण तुलना, विशेष रूप से संबंधपरक, वस्तु-उन्मुख प्रोग्रामिंग की एक सहमत और कठोर परिभाषा की कमी के कारण कठिन है;<ref name="DatePage650">C. J. Date, Introduction to Database Systems, 6th-ed., Page 650</ref> हालाँकि, डेट और डार्वेन ने वस्तु-उन्मुख प्रोग्रामिंग पर एक सैद्धांतिक आधार प्रस्तावित किया है जो [[RDBMS|सापेक्षिक डाटाबेस प्रबंध प्रणाली]] का समर्थन करने के लिए वस्तु-उन्मुख प्रोग्रामिंग को एक प्रकार के अनुकूलन योग्य डेटा प्रकार के रूप में उपयोग करता है।<ref name="ThirdManifesto">C. J. Date, Hugh Darwen. ''Foundation for Future Database Systems: The Third Manifesto'' (2nd Edition)</ref> हालांकि लेख में लॉरेंस क्रुबनेर ने दावा किया कि अन्य भाषाओं (एलआईएसपी बोलियों, कार्यात्मक भाषाओं, आदि) की तुलना में वस्तु-उन्मुख प्रोग्रामिंग भाषाओं में कोई अद्वितीय सामर्थ्य नहीं है, और अनावश्यक जटिलता का भारी भार डालती है।<ref name="lawrence">{{Cite web| last=Krubner| first=Lawrence| title=Object Oriented Programming is an expensive disaster which must end| url=http://www.smashcompany.com/technology/object-oriented-programming-is-an-expensive-disaster-which-must-end| publisher=smashcompany.com| access-date=14 October 2014| archive-url=https://web.archive.org/web/20141014233854/http://www.smashcompany.com/technology/object-oriented-programming-is-an-expensive-disaster-which-must-end| archive-date=14 October 2014| url-status=dead}}</ref>[[अलेक्जेंडर स्टेपानोव]] ऑब्जेक्ट ओरिएंटेशन की तुलना [[सामान्य प्रोग्रामिंग]] से प्रतिकूल रूप से करता है:<ref name="stepanov">{{Cite web| url=http://www.stlport.org/resources/StepanovUSA.html| title=STLport: An Interview with A. Stepanov| last=Stepanov| first=Alexander| access-date=21 April 2010| author-link=Alexander Stepanov}}</ref>
[[अलेक्जेंडर स्टेपानोव]] ऑब्जेक्ट ओरिएंटेशन की तुलना [[सामान्य प्रोग्रामिंग]] से प्रतिकूल रूप से करता है:<ref name="stepanov">{{Cite web| url=http://www.stlport.org/resources/StepanovUSA.html| title=STLport: An Interview with A. Stepanov| last=Stepanov| first=Alexander| access-date=21 April 2010| author-link=Alexander Stepanov}}</ref>


{{quote|मुझे वस्तु-उन्मुख प्रोग्रामिंग तकनीकी रूप से अनुचित लगता है। यह विश्व को उन इंटरफेस के संदर्भ में विघटित करने का प्रयास करता है जो एक ही प्रकार पर भिन्न होते हैं। वास्तविक समस्याओं से निपटने के लिए आपको कई प्रकार के इंटरफेस के बहु-वर्गीकृत बीजगणित वर्गों की आवश्यकता होती है। मुझे वस्तु-उन्मुख प्रोग्रामिंग दार्शनिक रूप से अनुचित लगता है। यह दावा करता है कि सब कुछ एक वस्तु है। अगर यह सच भी है तो यह कहना बहुत दिलचस्प नहीं है कि सब कुछ एक वस्तु है, और कुछ भी नहीं है।}}
{{quote|मुझे वस्तु-उन्मुख प्रोग्रामिंग तकनीकी रूप से अनुचित लगता है। यह विश्व को उन इंटरफेस के संदर्भ में विघटित करने का प्रयास करता है जो एक ही प्रकार पर भिन्न होते हैं। वास्तविक समस्याओं से निपटने के लिए आपको कई प्रकार के इंटरफेस के बहु-वर्गीकृत बीजगणित वर्गों की आवश्यकता होती है। मुझे वस्तु-उन्मुख प्रोग्रामिंग दार्शनिक रूप से अनुचित लगता है। यह दावा करता है कि सब कुछ एक वस्तु है। अगर यह सच भी है तो यह कहना बहुत दिलचस्प नहीं है कि सब कुछ एक वस्तु है, और कुछ भी नहीं है।}}
[[पॉल ग्राहम (कंप्यूटर प्रोग्रामर)]] ने सुझाव दिया है कि बड़ी कंपनियों के भीतर वस्तु-उन्मुख प्रोग्रामिंग की लोकप्रियता औसत प्रोग्रामर के बड़े (और प्रायः बदलते) समूहों के कारण है। ग्राहम के अनुसार, वस्तु-उन्मुख प्रोग्रामिंग द्वारा लगाया गया अनुशासन किसी एक प्रोग्रामर को बहुत अधिक नुकसान करने से रोकता है।<ref name="graham">{{Cite web| last=Graham| first=Paul| title=Why ARC isn't especially Object-Oriented.| url=http://www.paulgraham.com/noop.html| publisher=PaulGraham.com| access-date=13 November 2009| author-link=Paul Graham (computer programmer)}}</ref>
[[पॉल ग्राहम (कंप्यूटर प्रोग्रामर)]] ने सुझाव दिया है कि बड़ी कंपनियों के अंदर वस्तु-उन्मुख प्रोग्रामिंग की लोकप्रियता औसत प्रोग्रामर के बड़े (और प्रायः बदलते) समूहों के कारण है। ग्राहम के अनुसार, वस्तु-उन्मुख प्रोग्रामिंग द्वारा लगाया गया अनुशासन किसी एक प्रोग्रामर को बहुत अधिक नुकसान करने से रोकता है।<ref name="graham">{{Cite web| last=Graham| first=Paul| title=Why ARC isn't especially Object-Oriented.| url=http://www.paulgraham.com/noop.html| publisher=PaulGraham.com| access-date=13 November 2009| author-link=Paul Graham (computer programmer)}}</ref>
लियो ब्रॉडी ने वस्तुओं की स्टैंडअलोन प्रकृति और [[डुप्लिकेट कोड]] की प्रवृत्ति के बीच संबंध का सुझाव दिया है<ref>{{Cite book| url=http://thinking-forth.sourceforge.net/thinking-forth-ans.pdf| title=Thinking Forth| last=Brodie| first=Leo|pages=92–93 |year=1984 |access-date=4 May 2018}}</ref> खुद को न दोहराने के सिद्धांत का उल्लंघन करते हुए<ref>{{cite web| work=Category Extreme Programming| last=Hunt| first=Andrew| url=http://wiki.c2.com/?DontRepeatYourself|title=Don't Repeat Yourself| access-date=4 May 2018}}</ref> सॉफ्टवेयर विकास की।


स्टीव येगे ने नोट किया कि [[कार्यात्मक प्रोग्रामिंग]] के विपरीत:<ref name="yegge">{{Cite web|url=http://steve-yegge.blogspot.com/2006/03/execution-in-kingdom-of-nouns.html|title=Stevey's Blog Rants: Execution in the Kingdom of Nouns|access-date=20 May 2020}}</ref>
लियो ब्रॉडी ने वस्तुओं की स्टैंडअलोन प्रकृति और सॉफ़्टवेयर विकास के अपने आप को न दोहराने के सिद्धांत<ref>{{Cite book| url=http://thinking-forth.sourceforge.net/thinking-forth-ans.pdf| title=Thinking Forth| last=Brodie| first=Leo|pages=92–93 |year=1984 |access-date=4 May 2018}}</ref> के उल्लंघन में प्रतिरूप कोड की प्रवृत्ति के बीच एक संबंध का सुझाव दिया है।<ref>{{cite web| work=Category Extreme Programming| last=Hunt| first=Andrew| url=http://wiki.c2.com/?DontRepeatYourself|title=Don't Repeat Yourself| access-date=4 May 2018}}</ref>
 
स्टीव येगे ने उल्लेख किया कि [[कार्यात्मक प्रोग्रामिंग]] के विपरीत:<ref name="yegge">{{Cite web|url=http://steve-yegge.blogspot.com/2006/03/execution-in-kingdom-of-nouns.html|title=Stevey's Blog Rants: Execution in the Kingdom of Nouns|access-date=20 May 2020}}</ref>


{{quote|वस्तु उन्मुख प्रोग्रामिंग संज्ञाओं को सबसे पहले और सबसे महत्वपूर्ण रखती है। भाषण के एक हिस्से को आसन पर रखने के लिए आप इतनी दूर क्यों जाएंगे? एक प्रकार की अवधारणा को दूसरे पर प्राथमिकता क्यों देनी चाहिए? ऐसा नहीं है कि जैसे हम वास्तव में सोचते हैं, वस्तु उन्मुख प्रोग्रामिंग ने अचानक से क्रियाओं को कम महत्वपूर्ण बना दिया है। यह असाधारण रूप से विषम दृष्टिकोण है।}}
{{quote|वस्तु उन्मुख प्रोग्रामिंग संज्ञाओं को सबसे पहले और सबसे महत्वपूर्ण रखती है। भाषण के एक हिस्से को आसन पर रखने के लिए आप इतनी दूर क्यों जाएंगे? एक प्रकार की अवधारणा को दूसरे पर प्राथमिकता क्यों देनी चाहिए? ऐसा नहीं है कि जैसे हम वास्तव में सोचते हैं, वस्तु उन्मुख प्रोग्रामिंग ने अचानक से क्रियाओं को कम महत्वपूर्ण बना दिया है। यह असाधारण रूप से विषम दृष्टिकोण है।}}
[[क्लोजर]] के निर्माता [[अमीर हिक्की]] ने ऑब्जेक्ट प्रणाली को वास्तविक विश्व के अत्यधिक सरलीकृत मॉडल के रूप में वर्णित किया। उन्होंने समय को सही ढंग से मॉडल करने में वस्तु-उन्मुख प्रोग्रामिंग की अक्षमता पर जोर दिया, जो तेजी से समस्याग्रस्त हो रहा है क्योंकि सॉफ्टवेयर प्रणाली अधिक समवर्ती हो गए हैं।<ref name="hickey">Rich Hickey, JVM Languages Summit 2009 keynote, [http://www.infoq.com/presentations/Are-We-There-Yet-Rich-Hickey Are We There Yet?] November 2009.</ref>
[[क्लोजर]] के निर्माता [[अमीर हिक्की]] ने ऑब्जेक्ट प्रणाली को वास्तविक विश्व के अत्यधिक सरलीकृत मॉडल के रूप में वर्णित किया। उन्होंने समय को सही रूप से मॉडल करने में वस्तु-उन्मुख प्रोग्रामिंग की अक्षमता पर जोर दिया, जो तेजी से समस्याग्रस्त हो रहा है क्योंकि सॉफ्टवेयर प्रणाली अधिक समवर्ती हो गए हैं।<ref name="hickey">Rich Hickey, JVM Languages Summit 2009 keynote, [http://www.infoq.com/presentations/Are-We-There-Yet-Rich-Hickey Are We There Yet?] November 2009.</ref>
एरिक एस. रेमंड, एक [[यूनिक्स]] प्रोग्रामर और [[खुला स्रोत सॉफ्टवेयर]] एडवोकेट, उन दावों के आलोचक रहे हैं जो वस्तु-उन्मुख प्रोग्रामिंग को वन ट्रू सॉल्यूशन के रूप में प्रस्तुत करते हैं, और उन्होंने लिखा है कि वस्तु-उन्मुख प्रोग्रामिंग भाषा मोटी स्तरित प्रोग्राम को प्रोत्साहित करती हैं जो पारदर्शिता को नष्ट कर देती हैं। .<ref name="Eric S. Raymond 2003">{{cite web|url=http://www.catb.org/esr/writings/taoup/html/unix_and_oo.html|title=The Art of Unix Programming: Unix and Object-Oriented Languages|author=Eric S. Raymond|date=2003|access-date=6 August 2014}}</ref> रेमंड इसकी तुलना यूनिक्स और सी (प्रोग्रामिंग भाषा) के दृष्टिकोण से प्रतिकूल रूप से करता है।<ref name="Eric S. Raymond 2003"/>
 
एरिक एस. रेमंड, एक [[यूनिक्स]] प्रोग्रामर और मुक्त [[खुला स्रोत सॉफ्टवेयर|स्रोत सॉफ्टवेयर]] एडवोकेट, उन दावों के आलोचक रहे हैं जो वस्तु-उन्मुख प्रोग्रामिंग को वन ट्रू सॉल्यूशन के रूप में प्रस्तुत करते हैं, और उन्होंने लिखा है कि वस्तु-उन्मुख प्रोग्रामिंग भाषा निरंतर स्तरित प्रोग्राम को प्रोत्साहित करती हैं जो पारदर्शिता को नष्ट कर देती हैं। <ref name="Eric S. Raymond 2003">{{cite web|url=http://www.catb.org/esr/writings/taoup/html/unix_and_oo.html|title=The Art of Unix Programming: Unix and Object-Oriented Languages|author=Eric S. Raymond|date=2003|access-date=6 August 2014}}</ref> रेमंड इसकी तुलना यूनिक्स और C (प्रोग्रामिंग भाषा) के दृष्टिकोण से प्रतिकूल रूप से करता है।<ref name="Eric S. Raymond 2003" />
 
[[UTF-8|यूटीएफ-8]] और गो (प्रोग्रामिंग भाषा) के निर्माण में सम्मिलित प्रोग्रामर [[रोब पाइक]] ने वस्तु-उन्मुख प्रोग्रामिंग को कंप्यूटिंग के [[रोमन अंक]] कहा है।<ref>{{cite mailing list |url=http://groups.google.com/group/comp.os.plan9/msg/006fec195aeeff15 |title=[9fans] Re: Threads: Sewing badges of honor onto a Kernel |date=2 March 2004 |access-date=17 November 2016 |mailing-list=comp.os.plan9 |last=Pike |first=Rob |author-link=Rob Pike}}</ref> और कहा है कि वस्तु-उन्मुख प्रोग्रामिंग भाषाएं प्रायः [[डेटा संरचना]]ओं और [[कलन विधि]] से डेटा प्रकार पर ध्यान केंद्रित करती हैं।<ref>{{cite web |url=https://commandcenter.blogspot.com/2012/06/less-is-exponentially-more.html |title=Less is exponentially more |last1=Pike |first1=Rob |date=25 June 2012 |access-date=1 October 2016 }}</ref> इसके अतिरिक्त, वह एक जावा (प्रोग्रामिंग भाषा) प्रोफेसर का एक उदाहरण देते हैं, जिसकी समस्या का इडियोमैटिक (मुहावरेदार) समाधान केवल [[तालिका देखो|लुकउप तालिका]] का उपयोग करने के अतिरिक्त छह नई क्लासेस बनाना था।<ref>{{cite web |url=http://plus.google.com/+RobPikeTheHuman/posts/hoJdanihKwb |title=A few years ago I saw this page |last1=Pike |first1=Rob |access-date=1 October 2016 |date=14 November 2012|archive-url=https://web.archive.org/web/20180814173134/http://plus.google.com/+RobPikeTheHuman/posts/hoJdanihKwb |archive-date=14 August 2018 }}</ref>
 
इनहेरिटेंस के बारे में, रॉबर्ट सी. मार्टिन कहते हैं कि क्योंकि वे सॉफ्टवेयर हैं, संबंधित क्लास आवश्यक रूप से उन वस्तुओ के संबंधों को साझा नहीं करते हैं जिनका वे प्रतिनिधित्व करते हैं।<ref>{{cite web | url=https://www.youtube.com/watch?v=zHiWqnTWsn4 | title=Uncle Bob SOLID principles | website=[[YouTube]] }}</ref>


[[UTF-8]] और Go (प्रोग्रामिंग भाषा) के निर्माण में सम्मिलित एक प्रोग्रामर [[रोब पाइक]] ने वस्तु-उन्मुख प्रोग्रामिंग को कंप्यूटिंग के [[रोमन अंक]] कहा है।<ref>{{cite mailing list |url=http://groups.google.com/group/comp.os.plan9/msg/006fec195aeeff15 |title=[9fans] Re: Threads: Sewing badges of honor onto a Kernel |date=2 March 2004 |access-date=17 November 2016 |mailing-list=comp.os.plan9 |last=Pike |first=Rob |author-link=Rob Pike}}</ref> और कहा है कि वस्तु-उन्मुख प्रोग्रामिंग भाषाएं प्रायः [[डेटा संरचना]]ओं और [[कलन विधि]] से डेटा प्रकार पर ध्यान केंद्रित करती हैं।<ref>{{cite web |url=https://commandcenter.blogspot.com/2012/06/less-is-exponentially-more.html |title=Less is exponentially more |last1=Pike |first1=Rob |date=25 June 2012 |access-date=1 October 2016 }}</ref> इसके अतिरिक्त, वह एक जावा (प्रोग्रामिंग भाषा) प्रोफेसर का एक उदाहरण देते हैं, जिसकी समस्या का मुहावरेदार समाधान केवल [[तालिका देखो]] का उपयोग करने के अतिरिक्त छह नई कक्षाएं बनाना था।<ref>{{cite web |url=http://plus.google.com/+RobPikeTheHuman/posts/hoJdanihKwb |title=A few years ago I saw this page |last1=Pike |first1=Rob |access-date=1 October 2016 |date=14 November 2012|archive-url=https://web.archive.org/web/20180814173134/http://plus.google.com/+RobPikeTheHuman/posts/hoJdanihKwb |archive-date=14 August 2018 }}</ref>
इनहेरिटेंस के बारे में, रॉबर्ट सी. मार्टिन कहते हैं कि क्योंकि वे सॉफ्टवेयर हैं, संबंधित क्लास आवश्यक रूप से उन चीजों के संबंधों को साझा नहीं करते हैं जिनका वे प्रतिनिधित्व करते हैं।<ref>{{cite web | url=https://www.youtube.com/watch?v=zHiWqnTWsn4 | title=Uncle Bob SOLID principles | website=[[YouTube]] }}</ref>




== औपचारिक सेमेन्टिक्स ==
== औपचारिक सेमेन्टिक्स ==
{{see also|Formal semantics of programming languages}}
{{see also| प्रोग्रामिंग भाषाओं का औपचारिक शब्दार्थ}}
वस्तु-उन्मुख प्रणाली में ऑब्जेक्ट रन-टाइम इकाइयां हैं। वे किसी व्यक्ति, स्थान, बैंक खाते, डेटा की तालिका, या किसी भी आइटम का प्रतिनिधित्व कर सकते हैं जिसे प्रोग्राम को संभालना है।
वस्तु-उन्मुख प्रणाली में ऑब्जेक्ट रन-टाइम इकाइयां हैं। वे किसी व्यक्ति, स्थान, बैंक खाते, डेटा की तालिका, या किसी भी आइटम का प्रतिनिधित्व कर सकते हैं जिसे प्रोग्राम को संभालना है।


वस्तु-उन्मुख प्रोग्रामिंग में उपयोग की जाने वाली अवधारणाओं को औपचारिक रूप देने के कई प्रयास किए गए हैं। वस्तु-उन्मुख प्रोग्रामिंग अवधारणाओं की व्याख्या के रूप में निम्नलिखित अवधारणाओं और निर्माणों का उपयोग किया गया है:
वस्तु-उन्मुख प्रोग्रामिंग में उपयोग की जाने वाली अवधारणाओं को औपचारिक रूप देने के कई प्रयास किए गए हैं। वस्तु-उन्मुख प्रोग्रामिंग अवधारणाओं की व्याख्या के रूप में निम्नलिखित अवधारणाओं और निर्माणों का उपयोग किया गया है:
* [[कोलजेब्रा में]]<ref name=poll97>{{cite web|last=Poll|first=Erik|title=Subtyping and Inheritance for Categorical Datatypes|url=https://www.cs.ru.nl/E.Poll/papers/kyoto97.pdf|access-date=5 June 2011}}</ref>
* [[कोलजेब्रा में|सह बीजगणितीय डेटा प्रकार]]<ref name=poll97>{{cite web|last=Poll|first=Erik|title=Subtyping and Inheritance for Categorical Datatypes|url=https://www.cs.ru.nl/E.Poll/papers/kyoto97.pdf|access-date=5 June 2011}}</ref>
* [[पुनरावर्ती प्रकार]]
* [[पुनरावर्ती प्रकार]]
* समझाया राज्य
* प्रावरण अवस्था
* इनहेरिटेंस (वस्तु-उन्मुख प्रोग्रामिंग)
* इनहेरिटेंस (वस्तु-उन्मुख प्रोग्रामिंग)
* [[रिकॉर्ड (कंप्यूटर विज्ञान)]] वस्तुओं को समझने के लिए आधार हैं यदि [[समारोह शाब्दिक]] को फ़ील्ड्स (जैसे कार्यात्मक-प्रोग्रामिंग भाषाओं) में संग्रहीत किया जा सकता है, लेकिन वास्तविक कैलकुली को वस्तु-उन्मुख प्रोग्रामिंग की आवश्यक विशेषताओं को सम्मिलित करने के लिए काफी अधिक जटिल होना चाहिए। प्रणाली F-sub|System F के कई विस्तार<sub><:</sub>परिवर्तनीय वस्तुओं से संबंधित अध्ययन किया गया है;<ref name="AbadiCardelli"/>ये उपप्रकार बहुरूपता और [[पैरामीट्रिक बहुरूपता]] (जेनेरिक) दोनों की स्वीकृति देते हैं
* [[रिकॉर्ड (कंप्यूटर विज्ञान)]] वस्तुओं को समझने के लिए आधार हैं यदि फ़ंक्शन शाब्दिक को क्षेत्र (जैसे कार्यात्मक-प्रोग्रामिंग भाषाओं) में संग्रहीत किया जा सकता है, लेकिन वास्तविक कैलकुली को वस्तु-उन्मुख प्रोग्रामिंग की आवश्यक विशेषताओं को सम्मिलित करने के लिए अधिक जटिल होना चाहिए।सिस्टम F<: के कई विस्तार जो परिवर्तनशील वस्तुओं से संबंधित हैं, का अध्ययन किया गया है;<ref name="AbadiCardelli"/> ये सबटाइपिंग बहुरूपता और [[पैरामीट्रिक बहुरूपता]] ( सामान्य) दोनों की स्वीकृति देते हैं


वस्तुओं के पीछे एक सामान्य सहमति परिभाषा या सिद्धांत खोजने का प्रयास बहुत सफल प्रमाणित नहीं हुआ है (हालांकि, देखें Abadi & Cardelli, [http://portal.acm.org/citation.cfm?id=547964&dl=ACM&coll=portal A Theory of Objects]<ref name="AbadiCardelli">{{Cite book| first=Martin| last=Abadi |title=A Theory of Objects| url=http://portal.acm.org/citation.cfm?id=547964&dl=ACM&coll=portal| year=1996| access-date=21 April 2010| isbn = 978-0-387-94775-4| publisher = Springer-Verlag New York, Inc.| author-link=Martin Abadi|author2=Cardelli, Luca }}</ref> कई वस्तु-उन्मुख प्रोग्रामिंग अवधारणाओं और निर्माणों की औपचारिक परिभाषाओं के लिए), और प्रायः व्यापक रूप से अलग हो जाते हैं। उदाहरण के लिए, कुछ परिभाषाएँ मानसिक गतिविधियों पर और कुछ प्रोग्राम संरचना पर केंद्रित हैं। सरल परिभाषाओं में से एक यह है कि वस्तु-उन्मुख प्रोग्रामिंग मानचित्र डेटा संरचनाओं या सरणी का उपयोग करने का फंक्शन है जिसमें शीर्ष पर कुछ वाक्य रचनात्मक चीनी के साथ अन्य मानचित्रों में फ़ंक्शन और पॉइंटर्स सम्मिलित हो सकते हैं। नक्शों की क्लोनिंग (कभी-कभी प्रोटोटाइपिंग कहा जाता है) द्वारा विरासत का प्रदर्शन किया जा सकता है।
वस्तुओं के पीछे एक सामान्य सहमति परिभाषा या सिद्धांत खोजने का प्रयास बहुत सफल प्रमाणित नहीं हुआ है (हालांकि, देखें अबादी और कार्डेली, ए थ्योरी ऑफ ऑब्जेक्ट्स<ref name="AbadiCardelli">{{Cite book| first=Martin| last=Abadi |title=A Theory of Objects| url=http://portal.acm.org/citation.cfm?id=547964&dl=ACM&coll=portal| year=1996| access-date=21 April 2010| isbn = 978-0-387-94775-4| publisher = Springer-Verlag New York, Inc.| author-link=Martin Abadi|author2=Cardelli, Luca }}</ref> कई वस्तु-उन्मुख प्रोग्रामिंग अवधारणाओं और निर्माणों की औपचारिक परिभाषाओं के लिए), और प्रायः व्यापक रूप से अलग हो जाते हैं। उदाहरण के लिए, कुछ परिभाषाएँ मानसिक गतिविधियों पर और कुछ प्रोग्राम संरचना पर केंद्रित हैं। सामान्य परिभाषाओं में से एक यह है कि वस्तु-उन्मुख प्रोग्रामिंग मानचित्र डेटा संरचनाओं या सरणी का उपयोग करने का फंक्शन है जिसमें शीर्ष पर कुछ सिंटैक्टिक स्कूपिंग चीनी के साथ अन्य मानचित्रों में फ़ंक्शन और पॉइंटर्स सम्मिलित हो सकते हैं। नक्शों की क्लोनिंग (कभी-कभी "प्रोटोटाइपिंग" कहा जाता है) द्वारा इनहेरिटेंस का प्रदर्शन किया जा सकता है।


== यह भी देखें ==
== यह भी देखें ==
{{Portal|Computer programming}}
{{Portal|Computer programming}}
* [[प्रोग्रामिंग भाषाओं की तुलना (ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग)|प्रोग्रामिंग भाषाओं की तुलना (वस्तु-उन्मुख प्रोग्रामिंग)]]
* [[प्रोग्रामिंग भाषाओं की तुलना (ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग)|प्रोग्रामिंग भाषाओं की तुलना (वस्तु-उन्मुख प्रोग्रामिंग)]]
* [[प्रोग्रामिंग प्रतिमानों की तुलना]]
* [[प्रोग्रामिंग प्रतिमानों की तुलना|प्रोग्रामिंग पैराडिग्म की तुलना]]
* घटक आधारित सॉफ्टवेयर इंजीनियरिंग
* घटक आधारित सॉफ्टवेयर इंजीनियरिंग
* [[अनुबंध द्वारा डिजाइन]]
* [[अनुबंध द्वारा डिजाइन]]
Line 521: Line 523:


==बाहरी संबंध==
==बाहरी संबंध==
{{Wikiquote|Object-orientation}}
{{Wikiversity|at=Topic:Object-Oriented Programming}}
{{Wikibooks|Object Oriented Programming}}
* [http://www.codeproject.com/Articles/22769/Introduction-to-Object-Oriented-Programming-Concep Introduction to Object Oriented Programming Concepts (वस्तु-उन्मुख प्रोग्रामिंग) and More] by L.W.C. Nirosh
* [http://www.codeproject.com/Articles/22769/Introduction-to-Object-Oriented-Programming-Concep Introduction to Object Oriented Programming Concepts (वस्तु-उन्मुख प्रोग्रामिंग) and More] by L.W.C. Nirosh
*[https://thenewstack.io/why-are-so-many-developers-hating-on-object-oriented-programming/ Discussion on Cons of वस्तु-उन्मुख प्रोग्रामिंग]
*[https://thenewstack.io/why-are-so-many-developers-hating-on-object-oriented-programming/ Discussion on Cons of वस्तु-उन्मुख प्रोग्रामिंग]
* [http://java.sun.com/docs/books/tutorial/java/concepts/index.html वस्तु-उन्मुख प्रोग्रामिंग Concepts (Java Tutorials)]
* [http://java.sun.com/docs/books/tutorial/java/concepts/index.html वस्तु-उन्मुख प्रोग्रामिंग Concepts (Java Tutorials)]
{{Types of programming languages}}
{{Software engineering}}
{{Authority control}}
{{Authority control}}


{{DEFAULTSORT:Object-Oriented Programming}}[[Category: ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग | ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग ]] [[Category: प्रोग्रामिंग प्रतिमान]] [[Category: नॉर्वेजियन आविष्कार]]
{{DEFAULTSORT:Object-Oriented Programming}}
 
 


[[Category: Machine Translated Page]]
[[Category:All articles containing potentially dated statements|Object-Oriented Programming]]
[[Category:Created On 16/02/2023]]
[[Category:All articles with unsourced statements|Object-Oriented Programming]]
[[Category:Articles containing potentially dated statements from 2006|Object-Oriented Programming]]
[[Category:Articles with hatnote templates targeting a nonexistent page|Object-Oriented Programming]]
[[Category:Articles with unsourced statements from February 2010|Object-Oriented Programming]]
[[Category:CS1 English-language sources (en)]]
[[Category:CS1 errors]]
[[Category:Created On 16/02/2023|Object-Oriented Programming]]
[[Category:Lua-based templates|Object-Oriented Programming]]
[[Category:Machine Translated Page|Object-Oriented Programming]]
[[Category:Pages with empty portal template|Object-Oriented Programming]]
[[Category:Pages with script errors|Object-Oriented Programming]]
[[Category:Portal templates with redlinked portals|Object-Oriented Programming]]
[[Category:Short description with empty Wikidata description|Object-Oriented Programming]]
[[Category:Templates Vigyan Ready|Object-Oriented Programming]]
[[Category:Templates that add a tracking category|Object-Oriented Programming]]
[[Category:Templates that generate short descriptions|Object-Oriented Programming]]
[[Category:Templates using TemplateData|Object-Oriented Programming]]
[[Category:Webarchive template wayback links]]
[[Category:ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग| ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग ]]
[[Category:नॉर्वेजियन आविष्कार|Object-Oriented Programming]]
[[Category:प्रोग्रामिंग प्रतिमान|Object-Oriented Programming]]

Latest revision as of 10:55, 23 February 2023

वस्तु-उन्मुख प्रोग्रामिंग (ओओपी) वस्तु (ऑब्जेक्ट)" की अवधारणा पर आधारित एक प्रोग्रामिंग पैराडिग्म है, जिसमें डेटा और कोड हो सकते हैं। डेटा क्षेत्र के रूप में होता है (प्रायः विशेषता या गुण के रूप में जाना जाता है), और कोड प्रक्रियाओं के रूप में होता है (प्रायः विधियों के रूप में जाना जाता है)।

वस्तुओं की एक सामान्य विशेषता यह है कि प्रक्रियाएँ (या विधियाँ) उनसे जुड़ी होती हैं और वस्तु के डेटा क्षेत्रों तक पहुँच और संशोधित कर सकती हैं। वस्तु-उन्मुख प्रोग्रामिंग के इस ब्रांड में सामान्य रूप से एक विशेष नाम होता है जैसे this (कंप्यूटर प्रोग्रामिंग) या self वर्तमान वस्तु को संदर्भित करने के लिए उपयोग किया जाता है। वस्तु-उन्मुख प्रोग्रामिंग में, कंप्यूटर प्रोग्राम को उन वस्तुओं से बनाकर डिज़ाइन किया जाता है जो एक दूसरे के साथ परस्पर क्रिया करते हैं।[1][2] वस्तु-उन्मुख प्रोग्रामिंग भाषाएँ विविध हैं, लेकिन सबसे लोकप्रिय क्लास आधारित प्रोग्रामिंग जिसका अर्थ है कि ऑब्जेक्ट क्लास (कंप्यूटर विज्ञान) के उदाहरण (कंप्यूटर विज्ञान) हैं, जो उनके डेटा प्रकार को भी निर्धारित करते हैं।

सबसे व्यापक रूप से उपयोग की जाने वाली प्रोग्रामिंग भाषाओं में से कई (जैसे C ++, जावा, पायथन, आदि) बहु-पैराडिग्म प्रोग्रामिंग भाषा हैं। और वे वस्तु-उन्मुख प्रोग्रामिंग को अधिक या कम सीमा के लिए सामान्य रूप से अनिवार्य, प्रक्रियात्मक प्रोग्रामिंग के संयोजन में समर्थन करते हैं।

महत्वपूर्ण वस्तु-उन्मुख भाषाओं में एडीए (प्रोग्रामिंग भाषा), एक्शनस्क्रिप्ट, C++, सामान्य लिस्प, C #, डार्ट (प्रोग्रामिंग भाषा), एफिल (प्रोग्रामिंग भाषा), फोरट्रान 2003, हैक्स, जावा (प्रोग्रामिंग भाषा), जावास्क्रिप्ट, कोटलिन (प्रोग्रामिंग भाषा), लोगो (प्रोग्रामिंग भाषा), मैटलैब, ऑब्जेक्टिव-C, ऑब्जेक्ट पास्कल, पर्ल, पीएचपी, पायथन (प्रोग्रामिंग भाषा), आर (प्रोग्रामिंग भाषा), राकू (प्रोग्रामिंग भाषा), रूबी (प्रोग्रामिंग भाषा) ), स्काला (प्रोग्रामिंग भाषा), सिमस्क्रिप्ट, सिमुला, स्मॉलटॉक, स्विफ्ट (प्रोग्रामिंग भाषा), वाला (प्रोग्रामिंग भाषा) और विजुअल बेसिक.नेट सम्मिलित हैं।

इतिहास

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

1950 के दशक के अंत और 1960 के दशक की प्रारंभ में वस्तु-उन्मुख प्रोग्रामिंग के आधुनिक अर्थों में वस्तुओं को प्रेरक करने वाली और उन्मुख शब्दावली ने मेसाचुसेट्स प्रौद्योगिक संस्थान में अपनी पहली उपस्थिति दर्ज की। कृत्रिम बुद्धि समूह के वातावरण में, 1960 की प्रारंभ में, "वस्तु" गुणों (विशेषताओं) के साथ पहचानी गई वस्तुओं (एलआईएसपी (प्रोग्रामिंग भाषा) परमाणुओं) को संदर्भित कर सकती थी;[3][4] एलन केय ने बाद में 1966 में अपनी विचार पर एक शक्तिशाली प्रभाव के रूप में एलआईएसपी आंतरिक की विस्तृत समझ का उल्लेख दिया।[5]

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

एलन के, [5]

एक अन्य प्रारंभिक एमआईटी उदाहरण 1960-1961 में इवान सदरलैंड द्वारा रचित स्केचपैड था; स्केचपैड के बारे में अपने शोध प्रबंध पर आधारित 1963 की तकनीकी रिपोर्ट की शब्दावली में, सदरलैंड ने "ऑब्जेक्ट" और "इंस्टेंस" ("विशेषज्ञ" या "परिभाषा" द्वारा आच्छादित की गई क्लास अवधारणा के साथ) की धारणाओं को परिभाषित किया, हालांकि यह ग्राफिकल पारस्परिक क्रिया के लिए विशेष है।[6]इसके अतिरिक्त, एक मेसाचुसेट्स प्रौद्योगिक संस्थान एल्गोरिथम भाषा संस्करण, एईडी-0, ने डेटा संरचनाओं ("प्लेक्स", उस प्राकृत भाषा में) और प्रक्रियाओं के बीच एक सीधा लिंक स्थापित किया, जो बाद में संदेशों, विधियों और मेम्बर फंक्शन को पूर्वनिर्धारित करता है।[7][8]

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

1970 के दशक में, स्मॉलटाक प्रोग्रामिंग भाषा का पहला संस्करण ज़ेरॉक्स पालो आल्टो अनुसंधान केंद्र में एलन के, डैन इंगल्स और एडेल गोल्डबर्ग (कंप्यूटर वैज्ञानिक) द्वारा विकसित किया गया था। स्मालटाक -72 में एक प्रोग्रामिंग वातावरण सम्मिलित था इसे गतिशील रूप से टाइप किया गया था, और पहले इसकी व्याख्या की गई थी, संकलित नहीं की गई थी। स्मॉलटाक भाषा-स्तर पर ऑब्जेक्ट ओरिएंटेशन के अपने एप्लिकेशन और इसके ग्राफिकल विकास परिवेश के लिए विख्यात हुआ। स्मॉलटाक विभिन्न संस्करणों से प्रकट हुआ और भाषा में रुचि बढ़ी।[10] जबकि स्मॉलटाक सिमुला 67 में प्रस्तुत किए गए विचारों से प्रभावित था, इसे पूरी तरह से गतिशील प्रणाली के रूप में डिजाइन किया गया था जिसमें क्लास बनाई जा सकती थीं और गतिशील रूप से संशोधित की जा सकती थीं।[11]

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

1981 में, गोल्डबर्ग ने बाइट पत्रिका के अगस्त अंक को संपादित किया, जिसमें व्यापक दर्शकों के लिए स्मॉलटाक और वस्तु-उन्मुख प्रोग्रामिंग की प्रारंभ की गई। 1986 में, कंप्यूटिंग मशीनरी के लिए संघ ने वस्तु-उन्मुख प्रोग्रामिंग, सिस्टम्स, भाषाये और एप्लिकेशन (ओओपीएसएलए) पर पहला सम्मेलन आयोजित किया, जिसमें अप्रत्याशित रूप से 1,000 लोगों ने भाग लिया। 1980 के दशक के मध्य में ब्रैड कॉक्स द्वारा ऑब्जेक्टिव-C विकसित किया गया था, जिन्होंने आईटीटी इंक में स्मॉलटाक का उपयोग किया था, और बजेर्न स्ट्रॉस्ट्रुप, जिन्होंने अपनी पीएचडी थीसिस के लिए सिमुला का उपयोग किया था, अंततः वस्तु-उन्मुख C ++ बनाने के लिए गए।[10] 1985 में, बर्ट्रेंड मेयर ने एफिल (प्रोग्रामिंग भाषा) का पहला डिज़ाइन भी तैयार किया। सॉफ्टवेयर गुणवत्ता पर केंद्रित, एफिल विशुद्ध रूप से वस्तु-उन्मुख प्रोग्रामिंग भाषा है और संपूर्ण सॉफ्टवेयर जीवनचक्र का समर्थन करने वाला एक संकेत है। मेयर ने वस्तु-उन्मुख सॉफ्टवेयर निर्माण में सॉफ्टवेयर इंजीनियरिंग और कंप्यूटर विज्ञान से कुछ प्रमुख विचारों के आधार पर एफिल सॉफ्टवेयर विकास पद्धति का वर्णन किया। एफिल की गुणवत्ता पर ध्यान केंद्रित करने के लिए अनिवार्य है मेयर की विश्वसनीयता तंत्र, अनुबंध द्वारा डिजाइन, जो विधि और भाषा दोनों का एक अभिन्न भाग है।

टीआईओबीई इंडेक्स 2002 से 2018 तक प्रोग्रामिंग भाषा लोकप्रियता ग्राफ को मापता है। 2000 के दशक में वस्तु-उन्मुख जावा (प्रोग्रामिंग भाषा) (हरा) और और प्रक्रियात्मक प्रोग्रामिंग C (प्रोग्रामिंग भाषा) (काला) ने शीर्ष स्थान के लिए प्रतिस्पर्धा की।

1990 के दशक की प्रारंभ और मध्य में वस्तु-उन्मुख प्रोग्रामिंग प्रमुख प्रोग्रामिंग पैराडिग्म के रूप में विकसित हुई जब तकनीकों का समर्थन करने वाली प्रोग्रामिंग भाषाएं व्यापक रूप से उपलब्ध हो गईं। इनमें विजुअल फॉक्सप्रो 3.0,[12][13][14] C ++,[15] और डेल्फी (प्रोग्रामिंग भाषा) सम्मिलित है।[citation needed] ग्राफिकल यूज़र इंटरफ़ेस की बढ़ती लोकप्रियता से इसका प्रभुत्व और बढ़ गया, जो वस्तु-उन्मुख प्रोग्रामिंग तकनीकों पर बहुत अधिक निर्भर करता है। गुप्त रूप से संबंधित गतिशील जीयूआई पुस्तकालय और वस्तु-उन्मुख प्रोग्रामिंग भाषा का एक उदाहरण मैक ओएस एक्स पर कोको रूपरेखा में पाया जा सकता है, जो ऑब्जेक्टिव-C में लिखा गया है, जो स्मॉलटाक पर आधारित सी के लिए एक ऑब्जेक्ट-ओरिएंटेड, डायनेमिक मैसेजिंग एक्सटेंशन है। वस्तु-उन्मुख प्रोग्रामिंग टूलकिट ने इवेंट-संचालित प्रोग्रामिंग की लोकप्रियता को भी बढ़ाया (हालांकि यह अवधारणा वस्तु-उन्मुख प्रोग्रामिंग तक सीमित नहीं है)।

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

एडीए (प्रोग्रामिंग भाषा), बेसिक, फोरट्रान, पास्कल (प्रोग्रामिंग भाषा), और कोबोल सहित कई पूर्व-सम्मिलित भाषाओं में वस्तु-उन्मुख सुविधाओं को जोड़ा गया है। इन सुविधाओं को उन भाषाओं में जोड़ना जो प्रारंभ में उनके लिए डिज़ाइन नहीं की गई थीं, प्रायः कोड की संगतता और संरक्षण के साथ समस्याएं उत्पन्न हुईं।

हाल ही में, कई भाषाएं प्रकट हैं जो मुख्य रूप से वस्तु-उन्मुख हैं, लेकिन वे प्रक्रियात्मक पद्धति के साथ भी संगत हैं। ऐसी दो भाषाएँ हैं पायथन (प्रोग्रामिंग भाषा) और रूबी प्रोग्रामिंग भाषासन माइक्रोसिस्टम्स द्वारा विकसित जावा (प्रोग्रामिंग भाषा), साथ ही C# (प्रोग्रामिंग भाषा)| और विजुअल बेसिक नेटवर्क सक्षम प्रौद्योगिकी (वीबी नेट), दोनों ही माइक्रोसॉफ्ट के नेटवर्क सक्षम प्रौद्योगिकी के लिए डिज़ाइन की गई हैं। संभवत: व्यावसायिक रूप से सबसे महत्वपूर्ण हाल की वस्तु-उन्मुख भाषाएँ हैं। इन दो रूपरेखाओं में से प्रत्येक अपने तरीके से, कार्यान्वयन से एक अमूर्तता बनाकर वस्तु-उन्मुख प्रोग्रामिंग का उपयोग करने का लाभ दिखाता है। विजुअल बेसिक नेटवर्क सक्षम प्रौद्योगिकी और C# क्रॉस-भाषा इनहेरिटेंस का समर्थन करते हैं, एक भाषा में परिभाषित क्लासेस को दूसरी भाषा में परिभाषित सबक्लास क्लासेस की अनुमति देते हैं।

विशेषताएं

वस्तु-उन्मुख प्रोग्रामिंग वस्तुओं का उपयोग करती है, लेकिन सभी संबद्ध तकनीकों और संरचनाओं को प्रत्यक्ष रूप से उन भाषाओं में समर्थित नहीं किया जाता है जो वस्तु-उन्मुख प्रोग्रामिंग का समर्थन करने का दावा करती हैं। यह ऑपरेंड पर संचालन करता है। नीचे सूचीबद्ध विशेषताएं उन भाषाओं में सामान्य हैं जिन्हें दृढ़ता से क्लास-और वस्तु-उन्मुख (या वस्तु-उन्मुख प्रोग्रामिंग समर्थन के साथ बहु- पैराडिग्म) माना जाता है, उल्लेखनीय एक्सेप्शन(आक्षेप) का उल्लेख किया गया है।[16][17][18][19]


गैर-वस्तु-उन्मुख प्रोग्रामिंग भाषाओं के साथ साझा

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

मॉड्यूलर प्रोग्रामिंग समर्थन संगठनात्मक उद्देश्यों के लिए फाइलों और मॉड्यूल में समूह प्रक्रियाओं की क्षमता प्रदान करता है। मॉड्यूल नामस्थान हैं इसलिए एक मॉड्यूल में पहचानकर्ता किसी अन्य फ़ाइल या मॉड्यूल में समान नाम साझा करने वाली प्रक्रिया या वेरिएबल के साथ संघर्ष नहीं करेंगे।

ऑब्जेक्ट्स और क्लासेस

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

  • क्लास (कंप्यूटर विज्ञान) - किसी दिए गए प्रकार या वस्तु के क्लास के लिए डेटा प्रारूप और उपलब्ध प्रक्रियाओं की परिभाषाएँ; डेटा और प्रक्रियाएं भी सम्मिलित हो सकती हैं (जिसे क्लास विधियों के रूप में जाना जाता है), अर्थात क्लास में डेटा सदस्य और सदस्य फंक्शन होते हैं।
  • वस्तु (कंप्यूटर विज्ञान) - क्लास के उदाहरण

वस्तुएं कभी-कभी वास्तविक विश्व में पाई जाने वाली वस्तुओ के अनुरूप होती हैं। उदाहरण के लिए, एक ग्राफिक्स प्रोग्राम में सर्कल, स्क्वायर, मेनू जैसे ऑब्जेक्ट हो सकते हैं। एक ऑनलाइन शॉपिंग प्रणाली में शॉपिंग कार्ट, ग्राहक और उत्पाद जैसी वस्तुएं हो सकती हैं।[20] कभी-कभी ऑब्जेक्ट अधिक अमूर्त संस्थाओं का प्रतिनिधित्व करते हैं, जैसे एक ऑब्जेक्ट (वस्तु) जो एक खुली फ़ाइल का प्रतिनिधित्व करता है, या एक ऑब्जेक्ट जो यू.एस. प्रथागत से मीट्रिक में माप का अनुवाद करने की सेवा प्रदान करता है।

प्रत्येक वस्तु को एक विशेष क्लास का एक उदाहरण (कंप्यूटर विज्ञान) कहा जाता है (उदाहरण के लिए, एक वस्तु जिसका नाम क्षेत्र मैरी पर व्यवस्थित है, क्लास उपयोगकर्ता का एक उदाहरण हो सकता है)। वस्तु-उन्मुख प्रोग्रामिंग में प्रक्रियाओं को विधि (कंप्यूटर विज्ञान) के रूप में जाना जाता है; वेरिएबल को फील्ड (कंप्यूटर विज्ञान), सदस्यों, विशेषताओं या गुणों के रूप में भी जाना जाता है। यह निम्नलिखित शर्तों की ओर जाता है:

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

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

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

कुछ भाषाओं में क्लास और वस्तुओं को अन्य अवधारणाओं जैसे विशेषता (कंप्यूटर प्रोग्रामिंग) और मिक्सिन का उपयोग करके बनाया जा सकता है।

क्लास-आधारित बनाम प्रोटोटाइप-आधारित

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

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

गतिशील प्रेषण/संदेश देना

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

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

डेटा अमूर्तता

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

यदि कोई क्लास कॉलिंग कोड को आंतरिक वस्तु डेटा तक अभिगम्य की स्वीकृति नहीं देता है और केवल विधियों के माध्यम से अभिगम्य की स्वीकृति देता है, तो यह जानकारी छिपाने का एक रूप है जिसे अमूर्त (कंप्यूटर विज्ञान) के रूप में जाना जाता है। कुछ भाषाएँ (उदाहरण के लिए जावा) क्लास को स्पष्ट रूप से पहुँच प्रतिबंधों को प्रयुक्त करने देती हैं, उदाहरण के लिए private कीवर्ड के साथ आंतरिक डेटा को निरूपित करना और public कीवर्ड के साथ क्लास के बाहर कोड द्वारा उपयोग के लिए अभिप्रेत विधियों को निर्दिष्ट करना। विधियों को सार्वजनिक, निजी या मध्यवर्ती स्तरों जैसे protected (जो एक ही क्लास और उसके सबक्लास से अभिगम्य की स्वीकृति देता है, लेकिन एक अलग क्लास की वस्तुओं की स्वीकृति नहीं है) को भी डिज़ाइन किया जा सकता है। अन्य भाषाओं में (जैसे पायथन) यह केवल समागम द्वारा प्रयुक्त किया जाता है (उदाहरण के लिए, private विधियों में नाम हो सकते हैं जो बल देना से प्रारंभ होते हैं)। C #, स्विफ्ट और कोटलिन भाषाओं में, internal कीवर्ड केवल उसी असेंबली, पैकेज या मॉड्यूल में सम्मिलित फाइलों तक पहुंच की स्वीकृति देता है, जो क्लास के रूप में होती है।[21]


कैप्सूलीकरण

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

संरचना, इनहेरिटेंस, और डेलिगेशन

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

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

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

सार क्लासेस को वस्तुओं में तत्काल नहीं किया जा सकता है; वे केवल अन्य एसओएलआईडी क्लासेस में इनहेरिटेंस के उद्देश्य से सम्मिलित हैं जिन्हें तत्काल किया जा सकता है। जावा में, किसी क्लास को सबक्लासेस होने से रोकने के लिए finalकीवर्ड का उपयोग किया जा सकता है।

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

ओपन/क्लोज़ सिद्धांत इस बात को समर्थन करता है कि क्लासेस और फंक्शन विस्तार के लिए खुले होने चाहिए, लेकिन संशोधन के लिए बंद होने चाहिए।

डेलिगेशन (वस्तु-उन्मुख प्रोग्रामिंग) एक अन्य भाषा सुविधा है जिसका उपयोग इनहेरिटेंस के विकल्प के रूप में किया जा सकता है।

बहुरूपता

सबटाइपिंग - बहुरूपता (कंप्यूटर विज्ञान) का एक रूप तब होता है जब कॉलिंग कोड समर्थित पदानुक्रम में किस क्लास से स्वतंत्र हो सकता है, यह पैरेंट क्लास या उसके डिसेंडेंट में से एक पर काम कर रहा है। इस बीच, इनहेरिटेंस पदानुक्रम में वस्तुओं के बीच एक ही संचालन का नाम अलग-अलग गतिविधि कर सकता है।

उदाहरण के लिए, वृत्त और वर्ग प्रकार की वस्तुएँ आकार नामक एक सामान्य क्लास से ली गई हैं। प्रत्येक प्रकार के आकार के लिए ड्रा फ़ंक्शन प्रयुक्त होता है जो स्वयं को आकर्षित करने के लिए आवश्यक होता है जबकि कॉलिंग कोड किसी विशेष प्रकार के आकार को आकर्षित करने के प्रति सामान्य रह सकता है।

यह एक अन्य प्रकार का अमूर्त है जो क्लास पदानुक्रम के बाहर के कोड को सामान्य करता है और प्रयोजन के दृढ़ता से अंतर को सक्षम बनाता है।

खुला पुनरावर्तन

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

वस्तु-उन्मुख प्रोग्रामिंग भाषाएं

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

  • शुद्ध वस्तु-उन्मुख भाषाएँ कहलाने वाली भाषाएँ, क्योंकि उनमें सब कुछ एक वस्तु के रूप में निरंतर गतिविधि किया जाता है, मौलिक से लेकर वर्ण और विराम चिह्न तक, पूरी क्लास, प्रोटोटाइप, ब्लॉक, मॉड्यूल आदि तक तिविधि करते है। वे विशेष रूप से वस्तु-उन्मुख तरीके सुविधा के लिए डिज़ाइन किए गए थे, यहाँ तक कि प्रयुक्त करने के लिए प्रयुक्त किए गए थे। उदाहरण: रूबी (प्रोग्रामिंग भाषा), स्काला (प्रोग्रामिंग भाषा), स्मॉलटाक, एफिल (प्रोग्रामिंग भाषा), पन्ना (प्रोग्रामिंग भाषा),[23] जेएडीए (प्रोग्रामिंग भाषा), सेल्फ (प्रोग्रामिंग भाषा), राकू (प्रोग्रामिंग भाषा)।
  • मुख्य रूप से वस्तु-उन्मुख प्रोग्रामिंग के लिए भाषाएँ, लेकिन कुछ प्रक्रियात्मक तत्वों के साथ डिज़ाइन की गई। उदाहरण: जावा (प्रोग्रामिंग भाषा), पायथन (प्रोग्रामिंग भाषा), C++, C# (प्रोग्रामिंग भाषा), डेल्फी (प्रोग्रामिंग भाषा)/ऑब्जेक्ट पास्कल, वीबी.नेट।
  • भाषाएँ जो ऐतिहासिक रूप से प्रक्रियात्मक प्रोग्रामिंग हैं, लेकिन कुछ वस्तु-उन्मुख सुविधाओं के साथ विस्तारित की गई हैं। उदाहरण: पीएचपी, पर्ल, विज़ुअल बेसिक (बेसिक से प्राप्त), एमएटीएलएबी, कोबोल 2002, फोरट्रान 2003, एबीएपी, एडीए (प्रोग्रामिंग भाषा), पास्कल (प्रोग्रामिंग भाषा)।
  • वस्तुओं (क्लासेस, विधियों, इनहेरिटेंस) की अधिकांश विशेषताओं वाली भाषाएँ, लेकिन एक विशिष्ट मूल रूप में है। उदाहरण: ओबेरॉन (प्रोग्रामिंग भाषा) (ओबेरॉन-1 या ओबेरॉन-2)।
  • अमूर्त डेटा प्रकार समर्थन वाली भाषाएँ जिनका उपयोग वस्तु-उन्मुख प्रोग्रामिंग के समान करने के लिए किया जा सकता है, लेकिन ऑब्जेक्ट-ओरिएंटेशन की सभी विशेषताओं के बिना किया जा सकता है। इसमें ऑब्जेक्ट-आधारित और प्रोटोटाइप-आधारित प्रोग्रामिंग भाषाएं सम्मिलित हैं। उदाहरण: जावास्क्रिप्ट, लुआ (प्रोग्रामिंग भाषा), मोडुला-2, सीएलयू (प्रोग्रामिंग भाषा)।
  • चमेलेन भाषाएँ जो वस्तु-उन्मुख सहित कई पैराडिग्म का समर्थन करती हैं। टीसीएलओओ के लिए इनमें से टीसीएल सबसे अलग है, एक हाइब्रिड ऑब्जेक्ट प्रणाली जो प्रोटोटाइप-आधारित प्रोग्रामिंग और क्लास-आधारित वस्तु-उन्मुख दोनों का समर्थन करता है।

गतिशील भाषाओं में वस्तु-उन्मुख प्रोग्रामिंग

हाल के वर्षों में, वस्तु-उन्मुख प्रोग्रामिंग गतिशील प्रोग्रामिंग भाषाओं में विशेष रूप से लोकप्रिय हो गई है। पायथन (प्रोग्रामिंग भाषा), विंडोज पॉवरशेल, रूबी (प्रोग्रामिंग भाषा) और ग्रूवी (प्रोग्रामिंग भाषा) वस्तु-उन्मुख प्रोग्रामिंग सिद्धांतों पर निर्मित गतिशील भाषाएं हैं, जबकि पर्ल और पीएचपी पर्ल 5 और पीएचपी 4 के बाद से वस्तु-उन्मुख फीचर्स और संस्करण 6 के बाद से कोल्डफ्यूजन जोड़ रहे हैं।

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

एक नेटवर्क प्रोटोकॉल में वस्तु-उन्मुख प्रोग्रामिंग

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

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

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

डिजाइन पैटर्न

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

इनहेरिटेंस और गतिविधि सबटाइपिंग

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

चार डिजाइन पैटर्न का समूह

डिजाइन पैटर्न (पुस्तक) | डिजाइन पैटर्न: पुन: प्रयोज्य वस्तु-उन्मुख सॉफ्टवेयर के तत्व 1994 में एरिक गामा, रिचर्ड हेल्म, राल्फ जॉनसन (कंप्यूटर वैज्ञानिक), और जॉन व्लिससाइड्स द्वारा प्रकाशित एक प्रभावशाली पुस्तक है, जिसे प्रायः विनोदपूर्वक में गैंग ऑफ़ फोर" के रूप में संदर्भित किया जाता है। वस्तु-उन्मुख प्रोग्रामिंग की क्षमताओं और नुकसान की खोज के साथ-साथ, यह 23 सामान्य प्रोग्रामिंग समस्याओं और उन्हें संशोधित करने पैटर्न का वर्णन करता है। अप्रैल 2007 तक, पुस्तक अपने 36वें मुद्रण में थी।

पुस्तक निम्नलिखित पैटर्न का वर्णन करती है:

ऑब्जेक्ट-ओरिएंटेशन और डेटाबेस

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

ऐसे वस्तु डेटाबेस भी हैं जिनका उपयोग संबंधपरक डेटाबेस प्रबंधन प्रणाली को परिवर्तित करने के लिए किया जा सकता है, लेकिन ये संबंधपरक डेटाबेस प्रबंधन प्रणाली की तरह तकनीकी और व्यावसायिक रूप से सफल नहीं रहे हैं।

वास्तविक विश्व मॉडलिंग और रिश्ते

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

हालांकि, निकलॉस विर्थ (जिन्होंने विर्थ के नियम के रूप में पहचानी जाने वाले कथन को लोकप्रिय बनाया और हार्डवेयर की तुलना में सॉफ्टवेयर तेजी से मंद हो रहा है) ने अपने पत्र में वस्तु-उन्मुख प्रोग्रामिंग के बारे में कहा, ''लुकिंग ग्लास के माध्यम से अच्छे विचार'', यह पैराडिग्म 'वास्तविक विश्व में' प्रणालियों की संरचना को ध्यान से दर्शाता है, और इसलिए यह जटिल गतिविधि के साथ मॉडल जटिल प्रणालियों के लिए उपयुक्त है[27] (विपरीत केआईएसएस सिद्धांत)।

स्टीव येगे और अन्य ने उल्लेख किया कि प्राकृतिक भाषाओं में फंक्शन (विधियों/क्रियाओं) से पहले वस्तुओ (वस्तुओं/संज्ञाओं) को दृढ़ से प्राथमिकता देने के वस्तु-उन्मुख प्रोग्रामिंग दृष्टिकोण की कमी है।[28] यह समस्या वस्तु-उन्मुख प्रोग्रामिंग को प्रक्रियात्मक प्रोग्रामिंग की तुलना में अधिक जटिल समाधान करने का कारण बन सकती है।[29]



वस्तु-उन्मुख प्रोग्रामिंग और नियंत्रण संचालन

वस्तु-उन्मुख प्रोग्रामिंग को कोड के पुन: उपयोग और स्रोत कोड के सॉफ़्टवेयर संरक्षण को बढ़ाने के लिए विकसित किया गया था।[30] नियंत्रण संचालन के पारदर्शी प्रतिनिधित्व की कोई प्राथमिकता नहीं थी और इसका तात्पर्य एक संकलक द्वारा नियंत्रित किया जाना था। समानांतर हार्डवेयर और बहुप्रचारित कोडिंग, (कंप्यूटर विज्ञान) की बढ़ती प्रासंगिकता के साथ, पारदर्शी नियंत्रण संचालन विकसित करना अधिक महत्वपूर्ण हो जाता है, वस्तु-उन्मुख प्रोग्रामिंग के साथ कुछ प्राप्त करना कठिन होता है।[31][32][33][34]


उत्तरदायित्व- बनाम डेटा-संचालित डिज़ाइन

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

एसओएलआईडी और जीआरएएसपी दिशानिर्देश

एसओएलआईडी (वस्तु-उन्मुख डिज़ाइन) माइकल फेदर्स द्वारा आविष्कार किया गया एक मनेमोनिक (मेमोरी सहायक) है जो पाँच सॉफ्टवेयर इंजीनियरिंग डिज़ाइन सिद्धांतों को बताता है:

जीआरएएसपी (वस्तु-उन्मुख डिज़ाइन) (सामान्य अधीन समनुदेशन सॉफ्टवेयर पैटर्न) क्रेग लर्मन द्वारा समर्थित दिशानिर्देशों का एक अन्य समूह है।

आलोचना

वस्तु-उन्मुख प्रोग्रामिंग पैराडिग्म की कई कारणों से आलोचना की गई है, जिसमें पुन: प्रयोज्यता और मॉड्यूलता के अपने घोषित लक्ष्यों को पूरा नहीं करना,[35][36] और अन्य महत्वपूर्ण स्वरूपों (गणना/एल्गोरिदम) की कीमत पर सॉफ्टवेयर डिजाइन और मॉडलिंग (डेटा/ऑब्जेक्ट्स) के एक स्वरूप पर अधिक जोर देने के लिए सम्मिलित है।[37][38]

लुका कार्डेली ने दावा किया है कि वस्तु-उन्मुख प्रोग्रामिंग कोड प्रक्रियात्मक कोड की तुलना में आंतरिक रूप से कम कुशल है, वस्तु-उन्मुख प्रोग्रामिंग को संकलित करने में अधिक समय लग सकता है, और यह कि वस्तु-उन्मुख प्रोग्रामिंग भाषाओं में क्लास विस्तार और संशोधन के संबंध में अधिकतम दोषपूर्ण मॉड्यूलता गुण हैं, और यह अधिकतम जटिल हैं।[35] और बाद वाले बिंदु जो आर्मस्ट्रांग (प्रोग्रामिंग) द्वारा दोहराया गया है, जो एरलांग (प्रोग्रामिंग भाषा) के प्रमुख आविष्कारक हैं, जिन्हें यह कहते हुए उद्धृत किया गया है:[36]

वस्तु-उन्मुख भाषाओं के साथ समस्या यह है कि उनके पास यह सब अंतर्निहित वातावरण है जो वे अपने साथ ले जाते हैं। आप एक केला चाहते थे लेकिन आपको जो मिला वह केला और पूरे जंगल मे सिर्फ एक गोरिल्ला पकड़े हुए था।

पोटोक एट अल द्वारा एक अध्ययन वस्तु-उन्मुख प्रोग्रामिंग और प्रक्रियात्मक दृष्टिकोण के बीच उत्पादकता में कोई महत्वपूर्ण अंतर नहीं दिखाया है।[39]

क्रिस्टोफर जे. डेट ने कहा कि वस्तु-उन्मुख प्रोग्रामिंग की अन्य तकनीकों से महत्वपूर्ण तुलना, विशेष रूप से संबंधपरक, वस्तु-उन्मुख प्रोग्रामिंग की एक सहमत और कठोर परिभाषा की कमी के कारण कठिन है;[40] हालाँकि, डेट और डार्वेन ने वस्तु-उन्मुख प्रोग्रामिंग पर एक सैद्धांतिक आधार प्रस्तावित किया है जो सापेक्षिक डाटाबेस प्रबंध प्रणाली का समर्थन करने के लिए वस्तु-उन्मुख प्रोग्रामिंग को एक प्रकार के अनुकूलन योग्य डेटा प्रकार के रूप में उपयोग करता है।[41] हालांकि लेख में लॉरेंस क्रुबनेर ने दावा किया कि अन्य भाषाओं (एलआईएसपी बोलियों, कार्यात्मक भाषाओं, आदि) की तुलना में वस्तु-उन्मुख प्रोग्रामिंग भाषाओं में कोई अद्वितीय सामर्थ्य नहीं है, और अनावश्यक जटिलता का भारी भार डालती है।[42]अलेक्जेंडर स्टेपानोव ऑब्जेक्ट ओरिएंटेशन की तुलना सामान्य प्रोग्रामिंग से प्रतिकूल रूप से करता है:[37]

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

पॉल ग्राहम (कंप्यूटर प्रोग्रामर) ने सुझाव दिया है कि बड़ी कंपनियों के अंदर वस्तु-उन्मुख प्रोग्रामिंग की लोकप्रियता औसत प्रोग्रामर के बड़े (और प्रायः बदलते) समूहों के कारण है। ग्राहम के अनुसार, वस्तु-उन्मुख प्रोग्रामिंग द्वारा लगाया गया अनुशासन किसी एक प्रोग्रामर को बहुत अधिक नुकसान करने से रोकता है।[43]

लियो ब्रॉडी ने वस्तुओं की स्टैंडअलोन प्रकृति और सॉफ़्टवेयर विकास के अपने आप को न दोहराने के सिद्धांत[44] के उल्लंघन में प्रतिरूप कोड की प्रवृत्ति के बीच एक संबंध का सुझाव दिया है।[45]

स्टीव येगे ने उल्लेख किया कि कार्यात्मक प्रोग्रामिंग के विपरीत:[46]

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

क्लोजर के निर्माता अमीर हिक्की ने ऑब्जेक्ट प्रणाली को वास्तविक विश्व के अत्यधिक सरलीकृत मॉडल के रूप में वर्णित किया। उन्होंने समय को सही रूप से मॉडल करने में वस्तु-उन्मुख प्रोग्रामिंग की अक्षमता पर जोर दिया, जो तेजी से समस्याग्रस्त हो रहा है क्योंकि सॉफ्टवेयर प्रणाली अधिक समवर्ती हो गए हैं।[38]

एरिक एस. रेमंड, एक यूनिक्स प्रोग्रामर और मुक्त स्रोत सॉफ्टवेयर एडवोकेट, उन दावों के आलोचक रहे हैं जो वस्तु-उन्मुख प्रोग्रामिंग को वन ट्रू सॉल्यूशन के रूप में प्रस्तुत करते हैं, और उन्होंने लिखा है कि वस्तु-उन्मुख प्रोग्रामिंग भाषा निरंतर स्तरित प्रोग्राम को प्रोत्साहित करती हैं जो पारदर्शिता को नष्ट कर देती हैं। [47] रेमंड इसकी तुलना यूनिक्स और C (प्रोग्रामिंग भाषा) के दृष्टिकोण से प्रतिकूल रूप से करता है।[47]

यूटीएफ-8 और गो (प्रोग्रामिंग भाषा) के निर्माण में सम्मिलित प्रोग्रामर रोब पाइक ने वस्तु-उन्मुख प्रोग्रामिंग को कंप्यूटिंग के रोमन अंक कहा है।[48] और कहा है कि वस्तु-उन्मुख प्रोग्रामिंग भाषाएं प्रायः डेटा संरचनाओं और कलन विधि से डेटा प्रकार पर ध्यान केंद्रित करती हैं।[49] इसके अतिरिक्त, वह एक जावा (प्रोग्रामिंग भाषा) प्रोफेसर का एक उदाहरण देते हैं, जिसकी समस्या का इडियोमैटिक (मुहावरेदार) समाधान केवल लुकउप तालिका का उपयोग करने के अतिरिक्त छह नई क्लासेस बनाना था।[50]

इनहेरिटेंस के बारे में, रॉबर्ट सी. मार्टिन कहते हैं कि क्योंकि वे सॉफ्टवेयर हैं, संबंधित क्लास आवश्यक रूप से उन वस्तुओ के संबंधों को साझा नहीं करते हैं जिनका वे प्रतिनिधित्व करते हैं।[51]


औपचारिक सेमेन्टिक्स

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

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

  • सह बीजगणितीय डेटा प्रकार[52]
  • पुनरावर्ती प्रकार
  • प्रावरण अवस्था
  • इनहेरिटेंस (वस्तु-उन्मुख प्रोग्रामिंग)
  • रिकॉर्ड (कंप्यूटर विज्ञान) वस्तुओं को समझने के लिए आधार हैं यदि फ़ंक्शन शाब्दिक को क्षेत्र (जैसे कार्यात्मक-प्रोग्रामिंग भाषाओं) में संग्रहीत किया जा सकता है, लेकिन वास्तविक कैलकुली को वस्तु-उन्मुख प्रोग्रामिंग की आवश्यक विशेषताओं को सम्मिलित करने के लिए अधिक जटिल होना चाहिए।सिस्टम F<: के कई विस्तार जो परिवर्तनशील वस्तुओं से संबंधित हैं, का अध्ययन किया गया है;[53] ये सबटाइपिंग बहुरूपता और पैरामीट्रिक बहुरूपता ( सामान्य) दोनों की स्वीकृति देते हैं

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

यह भी देखें

प्रणाली

  • कैड्स
  • सामान्य ऑब्जेक्ट अनुरोध ब्रोकर संरचना (कॉरबा)
  • वितरित घटक वस्तु मॉडल
  • वितरित डेटा प्रबंधन संरचना
  • जेरू

मॉडलिंग भाषाएं

  • आईडीईएफ4
  • इंटरफ़ेस विवरण भाषा
  • लेपस3
  • यूएमएल

संदर्भ

  1. Kindler, E.; Krivy, I. (2011). "Object-Oriented Simulation of systems with sophisticated control". International Journal of General Systems: 313–343. {{cite journal}}: Cite journal requires |journal= (help)
  2. Lewis, John; Loftus, William (2008). Java Software Solutions Foundations of Programming Design 6th ed. Pearson Education Inc. ISBN 978-0-321-53205-3., section 1.6 "Object-Oriented Programming"
  3. McCarthy, J.; Brayton, R.; Edwards, D.; Fox, P.; Hodes, L.; Luckham, D.; Maling, K.; Park, D.; Russell, S. (March 1969). "LISP I Programmers Manual" (PDF). Boston, Massachusetts: Artificial Intelligence Group, M.I.T. Computation Center and Research Laboratory: 88f. Archived from the original (PDF) on 17 July 2010. In the local M.I.T. patois, association lists [of atomic symbols] are also referred to as "property lists", and atomic symbols are sometimes called "objects". {{cite journal}}: Cite journal requires |journal= (help)
  4. McCarthy, John; Abrahams, Paul W.; Edwards, Daniel J.; Hart, swapnil d.; Levin, Michael I. (1962). LISP 1.5 Programmer's Manual. MIT Press. p. 105. ISBN 978-0-262-13011-0. Object — a synonym for atomic symbol
  5. 5.0 5.1 "Dr. Alan Kay on the Meaning of "Object-Oriented Programming"". 2003. Retrieved 11 February 2010.
  6. Sutherland, I. E. (30 January 1963). "Sketchpad: A Man-Machine Graphical Communication System". Technical Report No. 296, Lincoln Laboratory, Massachusetts Institute of Technology via Defense Technical Information Center (stinet.dtic.mil). Archived from the original on 8 April 2013. Retrieved 17 July 2019.
  7. The Development of the Simula Languages, Kristen Nygaard, Ole-Johan Dahl, p.254 Uni-kl.ac.at
  8. Ross, Doug. "The first software engineering language". LCS/AI Lab Timeline. MIT Computer Science and Artificial Intelligence Laboratory. Retrieved 13 May 2010.
  9. 9.0 9.1 Holmevik, Jan Rune (1994). "Compiling Simula: A historical study of technological genesis" (PDF). IEEE Annals of the History of Computing. 16 (4): 25–37. doi:10.1109/85.329756. S2CID 18148999. Archived from the original (PDF) on 30 August 2017. Retrieved 3 March 2018.
  10. 10.0 10.1 Bertrand Meyer (2009). Touch of Class: Learning to Program Well with Objects and Contracts. Springer Science & Business Media. p. 329. Bibcode:2009tclp.book.....M. ISBN 978-3-540-92144-8.
  11. Kay, Alan. "The Early History of Smalltalk". Archived from the original on 10 July 2008. Retrieved 13 September 2007.
  12. 1995 (June) Visual FoxPro 3.0, FoxPro evolves from a procedural language to an object-oriented language. Visual FoxPro 3.0 introduces a database container, seamless client/server capabilities, support for ActiveX technologies, and OLE Automation and null support. Summary of Fox releases
  13. FoxPro History web site: Foxprohistory.org
  14. 1995 Reviewers Guide to Visual FoxPro 3.0: DFpug.de
  15. Khurana, Rohit (1 November 2009). Object Oriented Programming with C++, 1E. ISBN 978-81-259-2532-3.
  16. Deborah J. Armstrong. The Quarks of Object-Oriented Development. A survey of nearly 40 years of computing literature which identified a number of fundamental concepts found in the large majority of definitions of OOP, in descending order of popularity: Inheritance, Object, Class, Encapsulation, Method, Message Passing, Polymorphism, and Abstraction.
  17. John C. Mitchell, Concepts in programming languages, Cambridge University Press, 2003, ISBN 0-521-78098-5, p.278. Lists: Dynamic dispatch, abstraction, subtype polymorphism, and inheritance.
  18. Michael Lee Scott, Programming language pragmatics, Edition 2, Morgan Kaufmann, 2006, ISBN 0-12-633951-1, p. 470. Lists encapsulation, inheritance, and dynamic dispatch.
  19. Pierce, Benjamin (2002). Types and Programming Languages. MIT Press. ISBN 978-0-262-16209-8., section 18.1 "What is Object-Oriented Programming?" Lists: Dynamic dispatch, encapsulation or multi-methods (multiple dispatch), subtype polymorphism, inheritance or delegation, open recursion ("this"/"self")
  20. Booch, Grady (1986). Software Engineering with Ada. Addison Wesley. p. 220. ISBN 978-0-8053-0608-8. Perhaps the greatest strength of an object-oriented approach to development is that it offers a mechanism that captures a model of the real world.
  21. "What is Object Oriented Programming (OOP) In Simple Words? – Software Geek Bytes" (in English). 2023-01-05. Retrieved 2023-01-17.
  22. Jacobsen, Ivar; Magnus Christerson; Patrik Jonsson; Gunnar Overgaard (1992). Object Oriented Software Engineering. Addison-Wesley ACM Press. pp. 43–69. ISBN 978-0-201-54435-0.
  23. "The Emerald Programming Language". 26 February 2011.
  24. Neward, Ted (26 June 2006). "The Vietnam of Computer Science". Interoperability Happens. Archived from the original on 4 July 2006. Retrieved 2 June 2010.
  25. Meyer, Second Edition, p. 230
  26. M.Trofimov, OOOP – The Third "O" Solution: Open OOP. First Class, OMG, 1993, Vol. 3, issue 3, p.14.
  27. Wirth, Nicklaus (2006). "Good Ideas, Through the Looking Glass" (PDF). Computer. 39 (1): 28–39. doi:10.1109/mc.2006.20. S2CID 6582369. Archived from the original (PDF) on 12 October 2016. Retrieved 2 October 2016.
  28. Yegge, Steve (30 March 2006). "Execution in the Kingdom of Nouns". steve-yegge.blogspot.com. Retrieved 3 July 2010.
  29. Boronczyk, Timothy (11 June 2009). "What's Wrong with OOP". zaemis.blogspot.com. Retrieved 3 July 2010.
  30. Ambler, Scott (1 January 1998). "A Realistic Look at Object-Oriented Reuse". drdobbs.com. Retrieved 4 July 2010.
  31. Shelly, Asaf (22 August 2008). "Flaws of Object Oriented Modeling". Intel Software Network. Retrieved 4 July 2010.
  32. James, Justin (1 October 2007). "Multithreading is a verb not a noun". techrepublic.com. Archived from the original on 10 October 2007. Retrieved 4 July 2010.
  33. Shelly, Asaf (22 August 2008). "HOW TO: Multicore Programming (Multiprocessing) Visual C++ Class Design Guidelines, Member Functions". support.microsoft.com. Retrieved 4 July 2010.
  34. Robert Harper (17 April 2011). "Some thoughts on teaching FP". Existential Type Blog. Retrieved 5 December 2011.
  35. 35.0 35.1 Cardelli, Luca (1996). "Bad Engineering Properties of Object-Oriented Languages". ACM Comput. Surv. 28 (4es): 150–es. doi:10.1145/242224.242415. ISSN 0360-0300. S2CID 12105785. Retrieved 21 April 2010.
  36. 36.0 36.1 Armstrong, Joe. In Coders at Work: Reflections on the Craft of Programming. Peter Seibel, ed. Codersatwork.com Archived 5 March 2010 at the Wayback Machine, Accessed 13 November 2009.
  37. 37.0 37.1 Stepanov, Alexander. "STLport: An Interview with A. Stepanov". Retrieved 21 April 2010.
  38. 38.0 38.1 Rich Hickey, JVM Languages Summit 2009 keynote, Are We There Yet? November 2009.
  39. Potok, Thomas; Mladen Vouk; Andy Rindos (1999). "Productivity Analysis of Object-Oriented Software Developed in a Commercial Environment" (PDF). Software: Practice and Experience. 29 (10): 833–847. doi:10.1002/(SICI)1097-024X(199908)29:10<833::AID-SPE258>3.0.CO;2-P. S2CID 57865731. Retrieved 21 April 2010.
  40. C. J. Date, Introduction to Database Systems, 6th-ed., Page 650
  41. C. J. Date, Hugh Darwen. Foundation for Future Database Systems: The Third Manifesto (2nd Edition)
  42. Krubner, Lawrence. "Object Oriented Programming is an expensive disaster which must end". smashcompany.com. Archived from the original on 14 October 2014. Retrieved 14 October 2014.
  43. Graham, Paul. "Why ARC isn't especially Object-Oriented". PaulGraham.com. Retrieved 13 November 2009.
  44. Brodie, Leo (1984). Thinking Forth (PDF). pp. 92–93. Retrieved 4 May 2018.
  45. Hunt, Andrew. "Don't Repeat Yourself". Category Extreme Programming. Retrieved 4 May 2018.
  46. "Stevey's Blog Rants: Execution in the Kingdom of Nouns". Retrieved 20 May 2020.
  47. 47.0 47.1 Eric S. Raymond (2003). "The Art of Unix Programming: Unix and Object-Oriented Languages". Retrieved 6 August 2014.
  48. Pike, Rob (2 March 2004). "[9fans] Re: Threads: Sewing badges of honor onto a Kernel". comp.os.plan9 (Mailing list). Retrieved 17 November 2016.
  49. Pike, Rob (25 June 2012). "Less is exponentially more". Retrieved 1 October 2016.
  50. Pike, Rob (14 November 2012). "A few years ago I saw this page". Archived from the original on 14 August 2018. Retrieved 1 October 2016.
  51. "Uncle Bob SOLID principles". YouTube.
  52. Poll, Erik. "Subtyping and Inheritance for Categorical Datatypes" (PDF). Retrieved 5 June 2011.
  53. 53.0 53.1 Abadi, Martin; Cardelli, Luca (1996). A Theory of Objects. Springer-Verlag New York, Inc. ISBN 978-0-387-94775-4. Retrieved 21 April 2010.


अग्रिम पठन


बाहरी संबंध