सेल्फ (प्रोग्रामिंग भाषा): Difference between revisions

From Vigyanwiki
 
(20 intermediate revisions by 7 users not shown)
Line 1: Line 1:
{{Infobox programming language
<span lang= id dir= ltr >सेल्फ</span> एक वस्तु-उन्मुख [[प्रोग्रामिंग भाषा]] है जो ''[[प्रोटोटाइप-आधारित प्रोग्रामिंग]]'' की अवधारणा पर आधारित है। सेल्फ की शुरुआत स्मॉलटाक की एक बोली के रूप में हुई, जिसे [[गतिशील रूप से टाइप किया गया]] और [[समय-समय पर संकलन]] (JIT) के साथ-साथ वस्तुओं के लिए प्रोटोटाइप-आधारित दृष्टिकोण का उपयोग किया गया। यह पहली बार 1980 और 1990 के दशक में भाषा बनाने के लिए एक प्रायोगिक परीक्षण प्रणाली के रूप में उपयोग किया गया था।  2006 में सेल्फ अभी भी क्लेन प्रोजेक्ट के हिस्से के रूप में विकसित किया जा रहा था जो सेल्फ आभासी मशीन थी जो पूरी तरह से सेल्फ में लिखी गई थी। नवीनतम संस्करण 1 मई 2017 में जारी किया गया है।<ref>{{cite web|title=Self "Mandarin" 2017.1|url=https://blog.selflanguage.org/2017/05/24/self-mandarin-2017-1/|date=24 May 2017|access-date=24 May 2017|archive-url=https://web.archive.org/web/20170524053153/https://blog.selflanguage.org/2017/05/24/self-mandarin-2017-1/|archive-date=24 May 2017|url-status=dead}}</ref>
| name = Self
| logo = [[File:Self-logo.svg|200px|Logo]]
| paradigm = [[Object-oriented programming|object-oriented]] ([[prototype-based programming|prototype-based]])
| year = {{Start date and age|1987}}
| designer = [[David Ungar]], Randall Smith
| developer = David Ungar, Randall Smith, [[Stanford University]], [[Sun Microsystems]]
| latest release version = Mandarin 2017.1
| latest release date = {{Start date and age|2017|05|24}}
| typing = [[Type system|dynamic]], [[Strongly-typed programming language|strong]]
| implementations = Self
| dialects =
| influenced_by = [[Smalltalk]], [[APL (programming language)|APL]]<ref>{{cite journal|doi=10.1145/1238844.1238853|title=Self|journal=Proceedings of the Third ACM SIGPLAN Conference on History of Programming Languages (HOPL III)|year=2007|last1=Ungar|first1=David|last2=Smith|first2=Randall B.|isbn=9781595937667|s2cid=220937663}}</ref>
| influenced = [[NewtonScript]], [[JavaScript]], [[Io (programming language)|Io]], [[Agora (programming language)|Agora]], [[Squeak]], [[Lua (programming language)|Lua]], [[Factor (programming language)|Factor]], [[REBOL]]
| operating_system =
| license = BSD-like license
| website = {{URL|www.selflanguage.org}}
}}
<span lang= id dir= ltr >स्वयं</span> एक वस्तु-उन्मुख [[प्रोग्रामिंग भाषा]] है जो ''[[प्रोटोटाइप-आधारित प्रोग्रामिंग]]'' की अवधारणा पर आधारित है। स्वयं की शुरुआत स्मॉलटाक की एक बोली के रूप में हुई, जिसे [[गतिशील रूप से टाइप किया गया]] और [[समय-समय पर संकलन]] (JIT) के साथ-साथ वस्तुओं के लिए प्रोटोटाइप-आधारित दृष्टिकोण का उपयोग किया गया। यह पहली बार 1980 और 1990 के दशक में भाषा बनाने के लिए एक प्रायोगिक परीक्षण प्रणाली के रूप में उपयोग किया गया था।  2006 में स्वयं अभी भी क्लेन प्रोजेक्ट के हिस्से के रूप में विकसित किया जा रहा था जो स्वयं आभासी मशीन थी जो पूरी तरह से स्वयं में लिखी गई थी। नवीनतम संस्करण 2017.1 मई 2017 में जारी किया गया है।<ref>{{cite web|title=Self "Mandarin" 2017.1|url=https://blog.selflanguage.org/2017/05/24/self-mandarin-2017-1/|date=24 May 2017|access-date=24 May 2017|archive-url=https://web.archive.org/web/20170524053153/https://blog.selflanguage.org/2017/05/24/self-mandarin-2017-1/|archive-date=24 May 2017|url-status=dead}}</ref>


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


एक बिंदु पर स्मालटाक का एक संस्करण स्वयं में लागू किया गया था। क्योंकि यह [[समय-समय पर संकलन]] (JIT) का उपयोग करने में सक्षम था और इसने भी बहुत अच्छा प्रदर्शन दिया।<ref>{{cite journal|last1=Wolczko|first1=Mario|title=self includes: Smalltalk|journal=Workshop on Prototype-Based Languages, ECOOP '96, Linz, Austria|date=1996}}</ref>
एक बिंदु पर स्मालटाक का एक संस्करण सेल्फ में लागू किया गया था। क्योंकि यह [[समय-समय पर संकलन]] (JIT) का उपयोग करने में सक्षम था और इसने भी बहुत अच्छा प्रदर्शन दिया।<ref>{{cite journal|last1=Wolczko|first1=Mario|title=self includes: Smalltalk|journal=Workshop on Prototype-Based Languages, ECOOP '96, Linz, Austria|date=1996}}</ref>
== इतिहास ==
== इतिहास ==
स्वयं को 1986 में PARC (कंपनी) में काम करते हुए ज्यादातर [[डेविड अनगर]] और रान्डेल स्मिथ द्वारा बनाया गया था। उनका उद्देश्य वस्तु-उन्मुखी प्रोग्रामिंग भाषा संशोधन में कला की स्थिति को आगे बढ़ाना था। स्मॉलटाक -80 प्रयोगशालाओं द्वारा जारी किया गया था और उद्योग द्वारा इसे गंभीरता से लिया जाने लगा। वे [[स्टैनफोर्ड विश्वविद्यालय]] चले गए और 1987 में पहले वर्किंग स्वयं संकलक का निर्माण करते हुए भाषा पर काम करना जारी रखा गया।
सेल्फ को 1986 में PARC (कंपनी) में काम करते हुए ज्यादातर [[डेविड अनगर]] और रान्डेल स्मिथ द्वारा बनाया गया था। उनका उद्देश्य वस्तु-उन्मुखी प्रोग्रामिंग भाषा संशोधन में कला की स्थिति को आगे बढ़ाना था। स्मॉलटाक -80 प्रयोगशालाओं द्वारा जारी किया गया था और उद्योग द्वारा इसे गंभीरता से लिया जाने लगा। वे [[स्टैनफोर्ड विश्वविद्यालय]] चले गए और 1987 में पहले वर्किंग सेल्फ संकलक का निर्माण करते हुए भाषा पर काम करना जारी रखा गया।


पहली सार्वजनिक रिलीज़ 1990 में हुई थी और अगले साल टीम सन माइक्रोसिस्टम्स में चली गई जहाँ उन्होंने भाषा पर काम जारी रखा। 1995 में 4.0 संस्करण के साथ बड़े पैमाने पर निष्क्रिय होने तक कई नए रिलीज़ हुए। 4.3 संस्करण 2006 में जारी किया गया था और मैक ओएस एक्स और सोलारिस पर चलता था। 2010 में एक नई रिलीज,<ref>{{cite web|title=Self 4.4 released|url=https://blog.selflanguage.org/2010/07/16/self-4-4-released/|date=16 July 2010|access-date=24 May 2017|archive-url=https://web.archive.org/web/20171205194557/https://blog.selflanguage.org/2010/07/16/self-4-4-released/|archive-date=5 December 2017|url-status=dead}}</ref> संस्करण 4.4, एक समूह द्वारा विकसित किया गया है जिसमें कुछ मूल टीम और स्वतंत्र प्रोग्रामर सम्मिलित हैं और यह मैक ओएस एक्स और [[लिनक्स]] के लिए उपलब्ध है जैसा कि निम्नलिखित सभी संस्करण हैं। अनुवर्ती 4.5 जनवरी 2014 में<ref>{{cite web|title=Self Mallard (4.5.0) released|url=http://blog.selflanguage.org/2014/01/12/self-mallard-4-5-0-released/|date=12 January 2014|access-date=24 May 2017|archive-url=https://web.archive.org/web/20171206074534/https://blog.selflanguage.org/2014/01/12/self-mallard-4-5-0-released/|archive-date=6 December 2017|url-status=dead}}</ref> और तीन साल बाद संस्करण 1 मई 2017 में जारी किया गया था।
पहली सार्वजनिक रिलीज़ 1990 में हुई थी और अगले साल टीम सन माइक्रोप्रणाली में चली गई जहाँ उन्होंने भाषा पर काम जारी रखा। 1995 में 4.0 संस्करण के साथ बड़े पैमाने पर निष्क्रिय होने तक कई नए रिलीज़ हुए। 4.3 संस्करण 2006 में जारी किया गया था और मैक ओएसएक्स और सोलारिस पर चलता था। 2010 में एक नई रिलीज,<ref>{{cite web|title=Self 4.4 released|url=https://blog.selflanguage.org/2010/07/16/self-4-4-released/|date=16 July 2010|access-date=24 May 2017|archive-url=https://web.archive.org/web/20171205194557/https://blog.selflanguage.org/2010/07/16/self-4-4-released/|archive-date=5 December 2017|url-status=dead}}</ref> संस्करण 4.4 एक समूह द्वारा विकसित किया गया है जिसमें कुछ मूल टीम और स्वतंत्र प्रोग्रामर सम्मिलित हैं और यह मैक ओएस एक्स और [[लिनक्स]] के लिए उपलब्ध है जैसा कि निम्नलिखित सभी संस्करण हैं। अनुवर्ती 4.5 जनवरी 2014 में<ref>{{cite web|title=Self Mallard (4.5.0) released|url=http://blog.selflanguage.org/2014/01/12/self-mallard-4-5-0-released/|date=12 January 2014|access-date=24 May 2017|archive-url=https://web.archive.org/web/20171206074534/https://blog.selflanguage.org/2014/01/12/self-mallard-4-5-0-released/|archive-date=6 December 2017|url-status=dead}}</ref> और तीन साल बाद संस्करण 1 मई 2017 में जारी किया गया था।


[[मॉर्फिक (सॉफ्टवेयर)]] मूल रूप से स्वयं प्रोग्रामिंग भाषा के लिए रैंडी स्मिथ और जॉन मैलोनी द्वारा विकसित किया गया था।<ref>{{cite journal |last1=Maloney |first1=John H. |last2=Smith |first2=Randall B. |title=Directness and Liveness in the Morphic User Interface Construction Environment |journal=Proceedings of the 8th Annual ACM Symposium on User Interface and Software Technology |date=1995 |pages=21–28 |doi=10.1145/215585.215636 |isbn=089791709X |s2cid=14479674 |url=http://bibliography.selflanguage.org/directness.html |accessdate=24 March 2020}}</ref> मॉर्फिक को [[चीख़]], [[जावास्क्रिप्ट]], पायथन (प्रोग्रामिंग भाषा) और [[उद्देश्य सी]] सहित अन्य उल्लेखनीय [[आईओ प्रोग्रामिंग भाषा]] पोर्ट किया गया है।
[[मॉर्फिक (सॉफ्टवेयर)]] मूल रूप से सेल्फ प्रोग्रामिंग भाषा के लिए रैंडी स्मिथ और जॉन मैलोनी द्वारा विकसित किया गया था।<ref>{{cite journal |last1=Maloney |first1=John H. |last2=Smith |first2=Randall B. |title=Directness and Liveness in the Morphic User Interface Construction Environment |journal=Proceedings of the 8th Annual ACM Symposium on User Interface and Software Technology |date=1995 |pages=21–28 |doi=10.1145/215585.215636 |isbn=089791709X |s2cid=14479674 |url=http://bibliography.selflanguage.org/directness.html |accessdate=24 March 2020}}</ref> मॉर्फिक को [[चीख़]], [[जावास्क्रिप्ट]], पायथन (प्रोग्रामिंग भाषा) और [[उद्देश्य सी]] सहित अन्य उल्लेखनीय [[आईओ प्रोग्रामिंग भाषा]] पोर्ट किया गया है।


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


== प्रोटोटाइप-आधारित प्रोग्रामिंग लैंग्वेज ==
== प्रोटोटाइप-आधारित प्रोग्रामिंग भाषा ==
{{main|Prototype-based programming}}
{{main|Prototype-based programming}}
पारंपरिक वर्ग-आधारित OO भाषाएँ एक गहरी जड़ वाले द्वैत पर आधारित हैं
पारंपरिक वर्ग-आधारित ओओ भाषाएँ एक गहरी जड़ वाले द्वैत पर आधारित हैं
#कक्षाएं वस्तुओं के मूल गुणों और व्यवहारों को परिभाषित करती हैं।
#कक्षाएं वस्तुओं के मूल गुणों और व्यवहारों को परिभाषित करती हैं।
#वस्तु उदाहरण एक वर्ग की विशेष अभिव्यक्तियाँ हैं।
#वस्तु उदाहरण एक वर्ग की विशेष अभिव्यक्तियाँ हैं।


उदाहरण के लिए वस्तुओं की कल्पना करें <code>Vehicle</code>वर्ग का एक नाम और विभिन्न क्रियाएं करने की क्षमता होती है जैसे काम करने के लिए ड्राइव करना और निर्माण सामग्री वितरित करना। <code>Bob's car</code>वर्ग की एक विशेष वस्तु (उदाहरण) है <code>Vehicle</code>जिसका नाम "बॉब की कार" है। ''सिद्धांत रूप में कोई भी इसे निर्माण सामग्री वितरित करने''<code>Bob's car</code> के लिए कह कर एक संदेश भेज सकता है ।
उदाहरण के लिए वस्तुओं की कल्पना करें<code>वेहिकल</code>वर्ग का एक नाम और विभिन्न क्रियाएं करने की क्षमता होती है जैसे काम करने के लिए ड्राइव करना और निर्माण सामग्री वितरित करना। <code>बॉब की कार</code>वर्ग की एक विशेष वस्तु (उदाहरण) है<code>वेहिकल</code>जिसका नाम "बॉब की कार" है। ''सिद्धांत रूप में कोई भी इसे निर्माण सामग्री वितरित करने'' के लिए कह कर एक संदेश भेज सकता है ।


यह उदाहरण इस दृष्टिकोण के साथ समस्याओं में से एक को दिखाता है। बॉब की कार जो एक स्पोर्ट्स कार होती है, निर्माण सामग्री (किसी भी सार्थक अर्थ में) ले जाने और वितरित करने में सक्षम नहीं है लेकिन यह एक क्षमता है <code>Vehicle</code>s के लिए मॉडलिंग की जाती है। विशेषज्ञता बनाने के लिए उपवर्ग (सेट थ्योरी) आईएनजी के उपयोग से एक अधिक उपयोगी मॉडल उत्पन्न होता है <code>Vehicle</code>; उदाहरण के लिए <code>Sports Car</code>और <code>Flatbed Truck</code>केवल वर्ग की वस्तुएं <code>Flatbed Truck</code> निर्माण सामग्री वितरित करने के लिए एक तंत्र प्रदान करने की आवश्यकता है। स्पोर्ट्स कार जो उस तरह के काम के लिए अनुपयुक्त हैं केवल तेजी से ड्राइव करने की जरूरत है। हालांकि इस गहरे मॉडल को बनाने के दौरान अधिक अंतर्दृष्टि की आवश्यकता होती है जो समस्या उत्पन्न होने पर ही प्रकाश में आ सकती है।
यह उदाहरण इस दृष्टिकोण के साथ समस्याओं में से एक को दिखाता है। बॉब की कार जो एक स्पोर्ट्स कार होती है, निर्माण सामग्री (किसी भी सार्थक अर्थ में) ले जाने और वितरित करने में सक्षम नहीं है लेकिन यह एक क्षमता है<code>वेहिकल</code>के लिए मॉडलिंग की जाती है। विशेषज्ञता बनाने के लिए उपवर्ग (सेट थ्योरी) आईएनजी के उपयोग से एक अधिक उपयोगी मॉडल उत्पन्न होता है <code>वेहिकल</code>; उदाहरण के लिए <code>स्पोर्ट्स कार</code>और <code>फ्लैटबेड ट्रक</code>केवल वर्ग की वस्तुएं निर्माण सामग्री वितरित करने के लिए एक तंत्र प्रदान करने की आवश्यकता है। स्पोर्ट्स कार जो उस तरह के काम के लिए अनुपयुक्त हैं केवल तेजी से ड्राइव करने की जरूरत है। हालांकि इस गहरे मॉडल को बनाने के दौरान अधिक अंतर्दृष्टि की आवश्यकता होती है जो समस्या उत्पन्न होने पर ही प्रकाश में आ सकती है।


यह मुद्दा 'प्रोटोटाइप' के पीछे प्रेरक कारकों में से एक है। जब तक कोई निश्चित रूप से भविष्यवाणी नहीं कर सकता है कि दूर के भविष्य में वस्तुओं और वर्गों के एक समूह के गुण क्या होंगे, तब तक कोई वर्ग पदानुक्रम को ठीक से बनाया नहीं जा सकता है। अक्सर कार्यक्रम को अंततः अतिरिक्त व्यवहारों की आवश्यकता होती है और वस्तुओं को अलग तरीके से तोड़ने के लिए सिस्टम के अनुभागों को फिर से बनाने की आवश्यकता होगी।{{Citation needed|date=February 2007}} स्मॉलटाक जैसी शुरुआती ओओ भाषाओं के अनुभव से पता चला है कि इस तरह का मुद्दा बार-बार सामने आया। सिस्टम एक बिंदु तक बढ़ने लगते हैं और फिर बहुत कठोर हो जाते हैं क्योंकि प्रोग्रामर के कोड के नीचे गहरे बुनियादी वर्ग केवल गलत हो जाते हैं। मूल वर्ग को आसानी से बदलने के किसी तरीके के बिना गंभीर समस्याएँ उत्पन्न हो सकती हैं।{{Citation needed|date=February 2007}}
यह विषय 'प्रोटोटाइप' के पीछे प्रेरक कारकों में से एक है। जब तक कोई निश्चित रूप से भविष्यवाणी नहीं कर सकता है कि दूर के भविष्य में वस्तुओं और वर्गों के एक समूह के गुण क्या होंगे, तब तक कोई वर्ग पदानुक्रम को ठीक से बनाया नहीं जा सकता है। अक्सर कार्यक्रम को अंततः अतिरिक्त व्यवहारों की आवश्यकता होती है और वस्तुओं को अलग तरीके से तोड़ने के लिए प्रणाली के अनुभागों को फिर से बनाने की आवश्यकता होगी। स्मॉलटाक जैसी शुरुआती ओओ भाषाओं के अनुभव से पता चला है कि इस तरह का विषय बार-बार सामने आया। प्रणाली एक बिंदु तक बढ़ने लगते हैं और फिर बहुत कठोर हो जाते हैं क्योंकि प्रोग्रामर के संकेत के नीचे गहरे बुनियादी वर्ग केवल गलत हो जाते हैं। मूल वर्ग को आसानी से बदलने के किसी तरीके के बिना गंभीर समस्याएँ उत्पन्न हो सकती हैं।


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


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


किसी वर्ग पर आधारित किसी वस्तु का उदाहरण होने के बजाय स्वयं में एक उपस्थित वस्तु की एक प्रति बनाता है और उसे बदलता है। इसलिए <code>Bob's car</code> उपस्थित वेहिकल वस्तु की एक कॉपी बनाकर बनाया जाएगा और फिर ड्राइव फास्ट मेथड को जोड़कर इस तथ्य को मॉडलिंग करते हुए कि यह [[पोर्श 911]] होता है। मुख्य रूप से कॉपी बनाने के लिए उपयोग की जाने वाली मूल वस्तुओं को प्रोटोटाइप के रूप में जाना जाता है। इस तकनीक को गतिशीलता को बहुत सरल बनाने का दावा किया जाता है। यदि कोई उपस्थित वस्तु (या वस्तुओं का सेट) एक अपर्याप्त मॉडल साबित होती है, तो एक प्रोग्रामर सही व्यवहार के साथ एक संशोधित वस्तु बना सकता है और इसके बजाय उसका उपयोग कर सकता है। कोड जो उपस्थित वस्तुओं का उपयोग करता है उसे बदला नहीं जाता है।
किसी वर्ग पर आधारित किसी वस्तु का उदाहरण होने के अतिरिक्त सेल्फ में एक उपस्थित वस्तु की एक प्रति बनाता है और उसे बदलता है। इसलिए <code>बॉब की कार</code> उपस्थित वेहिकल वस्तु की एक कॉपी बनाकर बनाया जाएगा और फिर ड्राइव फास्ट मेथड को जोड़कर इस तथ्य को मॉडलिंग करते हुए कि यह [[पोर्श 911]] होता है। मुख्य रूप से कॉपी बनाने के लिए उपयोग की जाने वाली मूल वस्तुओं को प्रोटोटाइप के रूप में जाना जाता है। इस तकनीक को गतिशीलता को बहुत सरल बनाने का दावा किया जाता है। यदि कोई उपस्थित वस्तु (या वस्तुओं का सेट) एक अपर्याप्त मॉडल साबित होती है, तो एक प्रोग्रामर सही व्यवहार के साथ एक संशोधित वस्तु बना सकता है और इसके अतिरिक्त उसका उपयोग कर सकता है। संकेत जो उपस्थित वस्तुओं का उपयोग करता है उसे बदला नहीं जाता है।


== विवरण ==
== विवरण ==
स्वयं वस्तु स्लॉट्स का एक संग्रह है। स्लॉट एक्सेसर विधियाँ हैं जो मान लौटाती हैं और स्लॉट के नाम के बाद एक कोलन रखने से मान सेट हो जाता है। उदाहरण के लिए नाम नामक स्लॉट के लिए
सेल्फ वस्तु स्लॉट्स का एक संग्रह है। स्लॉट एक्सेसर विधियाँ हैं जो मान लौटाती हैं और स्लॉट के नाम के बाद एक कोलन रखने से मान सेट हो जाता है। उदाहरण के लिए नाम नामक स्लॉट के लिए
<syntaxhighlight lang="smalltalk">मेराव्यक्ति  नाम</syntaxhighlight>
<syntaxhighlight lang="smalltalk">myPerson name</syntaxhighlight>
नाम में मान लौटाता है और
returns the value in name, and
<syntaxhighlight lang="smalltalk">मेरा व्यक्ति  नाम: 'फू'</syntaxhighlight>
<syntaxhighlight lang="smalltalk">myPerson name:'foo'</syntaxhighlight>
इसे सेट करता है।
इसे सेट करता है।


स्वयं स्मॉलटॉक की तरह प्रवाह नियंत्रण और अन्य कर्तव्यों के लिए ब्लॉक का उपयोग करता है। विधियाँ ऐसी वस्तुएँ हैं जिनमें स्लॉट्स के अतिरिक्त कोड होते है (जो वे तर्कों और अस्थायी मानों के लिए उपयोग करते हैं) और किसी अन्य वस्तु की तरह ही स्वयं स्लॉट में रखा जा सकता है: उदाहरण के लिए एक संख्या। वाक्य - विन्यास दोनों ही स्थितियो में समान रहता है।
सेल्फ स्मॉलटॉक की तरह प्रवाह नियंत्रण और अन्य कर्तव्यों के लिए ब्लॉक का उपयोग करता है। विधियाँ ऐसी वस्तुएँ हैं जिनमें स्लॉट्स के अतिरिक्त संकेत होते है (जो वे तर्कों और अस्थायी मानों के लिए उपयोग करते हैं) और किसी अन्य वस्तु की तरह ही सेल्फ स्लॉट में रखा जा सकता है: उदाहरण के लिए एक संख्या। वाक्य - विन्यास दोनों ही स्थितियो में समान रहता है।


ध्यान दें कि स्वयं में फ़ील्ड और विधियों के बीच कोई अंतर नहीं है: सब कुछ एक स्लॉट है। संदेशों के माध्यम से स्लॉट तक पहुँचने के बाद से स्वयं में वाक्य - विन्यास का अधिकांश भाग बनता है, कई संदेश स्वयं को भेजे जाते हैं और स्वयं को छोड़ा जा सकता है।
ध्यान दें कि सेल्फ में फ़ील्ड और विधियों के बीच कोई अंतर नहीं है: सब कुछ एक स्लॉट है। संदेशों के माध्यम से स्लॉट तक पहुँचने के बाद से सेल्फ में वाक्य - विन्यास का अधिकांश भाग बनता है, कई संदेश सेल्फ को भेजे जाते हैं और सेल्फ को छोड़ा जा सकता है।


=== बेसिक वाक्य - विन्यास ===
=== बेसिक वाक्य - विन्यास ===
स्लॉट तक पहुँचने के लिए वाक्य - विन्यास स्मॉलटाक के समान है। तीन प्रकार के संदेश उपलब्ध हैं:
स्लॉट तक पहुँचने के लिए वाक्य - विन्यास स्मॉलटाक के समान है। तीन प्रकार के संदेश उपलब्ध हैं:


; एकल
;unary : <code>''receiver'' slot_name</code>
: <code>''receiver'' slot_name</code>
;binary : <code>''receiver'' + ''argument''</code>
; द्विआधारी
;keyword : <code>''receiver'' keyword: ''arg1'' With: ''arg2''</code>
: <code>''receiver'' + ''argument''</code>
; कीवर्ड
: <code>''receiver'' keyword: ''arg1'' With: ''arg2''</code>


सभी संदेश परिणाम लौटाते हैं इसलिए रिसीवर (यदि स्थित है) और तर्क स्वयं अन्य संदेशों का परिणाम हो सकते हैं। एक अवधि के बाद एक संदेश का मतलब है कि स्वयं लौटाए गए मान को त्याग देगा। उदाहरण के लिए:
सभी संदेश परिणाम लौटाते हैं इसलिए रिसीवर (यदि स्थित है) और तर्क सेल्फ अन्य संदेशों का परिणाम हो सकते हैं। एक अवधि के बाद एक संदेश का मतलब है कि सेल्फ लौटाए गए मान को त्याग देगा। उदाहरण के लिए:


<syntaxhighlight lang="smalltalk">'हैलो वर्ल्ड!' प्रिंट ।
<syntaxhighlight lang="smalltalk">'Hello, World!' print.</syntaxhighlight>


यह हैलो वर्ल्ड प्रोग्राम का सेल्फ वर्जन है । सिंटैक्स 'एक शाब्दिक स्ट्रिंग ऑब्जेक्ट को इंगित करता है। अन्य शाब्दिक में संख्याएँ, ब्लॉक और सामान्य वस्तुएँ शामिल हैं।
यह हैलो वर्ल्ड प्रोग्राम का सेल्फ वर्जन है । सिंटैक्स <code>'</code>एक शाब्दिक स्ट्रिंग ऑब्जेक्ट को इंगित करता है। अन्य शाब्दिक में संख्याएँ, ब्लॉक और सामान्य वस्तुएँ सम्मिलित हैं।


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


मान्य: आधार  तल  
मान्य:  आधार  तल  
          बीच:  संयुक्ताक्षर  तल  +  ऊँचाई
          और:  आधार  शीर्ष  /  स्केल  कारक ।</syntaxhighlight>


     
<syntaxhighlight lang="smalltalk">valid: base bottom
          between: ligature bottom + height
          And: base top / scale factor.</syntaxhighlight>
स्पष्ट रूप से पार्स किया जा सकता है और इसका मतलब वही है:
स्पष्ट रूप से पार्स किया जा सकता है और इसका मतलब वही है:
<syntaxhighlight lang="smalltalk">valid: ((base bottom)
            between: ((ligature bottom) + height)
            And: ((base top) / (scale factor))).</syntaxhighlight>


<वाक्यविन्यास हाइलाइट लैंग = स्मॉलटॉक> मान्य: ((आधार नीचे)
            बीच: ((संयुक्ताक्षर नीचे) + ऊंचाई)
            और: ((बेस टॉप) / (स्केल फैक्टर))।</syntaxhighlight>


स्मॉलटाक -80 में समान अभिव्यक्ति को इस प्रकार लिखा जाएगा:
स्मॉलटाक -80 में समान अभिव्यक्ति को इस प्रकार लिखा जाएगा:
<syntaxhighlight lang="smalltalk">valid := self base bottom
            between: self ligature bottom + self height
            and: self base top / self scale factor.</syntaxhighlight>


<वाक्यविन्यास हाइलाइट लैंग = स्मॉलटॉक> मान्य: = स्वयं आधार नीचे
मान लिया जाये<code>बेस,</code><code>लिगेचर</code>,<code>ऊंचाई</code>और<code>स्केल</code>के [[उदाहरण चर]] नहीं थे <code>सेल्फ</code>लेकिन वास्तव में तरीके थे।
            बीच: स्वयं  लिगेचर बॉटम + स्वयं  हाइट
            और: स्वयं  बेस टॉप / स्वयं  स्केल फैक्टर।<nowiki></syntaxhighlight></nowiki>


मान लिया जाये <code>base</code>, <code>ligature</code>, <code>height</code> और <code>scale</code> के [[उदाहरण चर]] नहीं थे <code>स्वयं</code>लेकिन वास्तव मेंत रीके थे।
[[Category:1987 में बनाई गई प्रोग्रामिंग लैंग्वेज|Self (Programming Language)]]
[[Category:1987 सॉफ्टवेयर|Self (Programming Language)]]
[[Category:All articles with dead external links|Self (Programming Language)]]
[[Category:Articles with dead external links from June 2016|Self (Programming Language)]]
[[Category:Articles with hatnote templates targeting a nonexistent page|Self (Programming Language)]]
[[Category:Collapse templates|Self (Programming Language)]]
[[Category:Created On 17/02/2023|Self (Programming Language)]]
[[Category:Machine Translated Page|Self (Programming Language)]]
[[Category:Navigational boxes| ]]
[[Category:Navigational boxes without horizontal lists|Self (Programming Language)]]
[[Category:Official website not in Wikidata|Self (Programming Language)]]
[[Category:Pages with script errors|Self (Programming Language)]]
[[Category:Sidebars with styles needing conversion|Self (Programming Language)]]
[[Category:Template documentation pages|Documentation/doc]]
[[Category:Templates Vigyan Ready|Self (Programming Language)]]
[[Category:Templates generating microformats|Self (Programming Language)]]
[[Category:Templates that are not mobile friendly|Self (Programming Language)]]
[[Category:Templates using TemplateData|Self (Programming Language)]]
[[Category:Wikipedia metatemplates|Self (Programming Language)]]
[[Category:क्रॉस-प्लेटफॉर्म मुफ्त सॉफ्टवेयर|Self (Programming Language)]]
[[Category:गतिशील प्रोग्रामिंग भाषाएँ|Self (Programming Language)]]
[[Category:गतिशील रूप से टाइप की गई प्रोग्रामिंग भाषाएँ|Self (Programming Language)]]
[[Category:निःशुल्क संकलक और दुभाषिए|Self (Programming Language)]]
[[Category:प्रोग्रामिंग भाषा|Self (Programming Language)]]
[[Category:प्रोटोटाइप-आधारित प्रोग्रामिंग भाषाएँ|Self (Programming Language)]]
[[Category:वस्तु-उन्मुख प्रोग्रामिंग भाषाएँ|Self (Programming Language)]]


=== नई वस्तुएं बनाना ===
=== नई वस्तुएं बनाना ===
थोड़ा और जटिल उदाहरण पर विचार करें:
थोड़ा और जटिल उदाहरण पर विचार करें:


<syntaxhighlight lang="smalltalk">लेबलविजेट  कॉपी  लेबल: 'हैलो, वर्ल्ड!' .</syntaxhighlight>
<syntaxhighlight lang="smalltalk">labelWidget copy label: 'Hello, World!'.</syntaxhighlight>


कॉपी संदेश के साथ लेबलविजेट वस्तु की प्रतिलिपि बनाता है (इस बार कोई शॉर्टकट नहीं है), फिर इसे लेबल नामक स्लॉट में हैलो वर्ल्ड डालने के लिए एक संदेश भेजता है। अब इसके साथ कुछ करना है:
कॉपी संदेश के साथ लेबलविजेट वस्तु की प्रतिलिपि बनाता है (इस बार कोई शॉर्टकट नहीं है), फिर इसे लेबल नामक स्लॉट में हैलो वर्ल्ड डालने के लिए एक संदेश भेजता है। अब इसके साथ कुछ करना है:


<syntaxhighlight lang="smalltalk">( डेस्कटॉप  सक्रियविंडो ) ड्रा: ( लेबलविजेट  कॉपी  लेबल: 'हैलो, वर्ल्ड!' ) </syntaxhighlight>
<syntaxhighlight lang="smalltalk">(desktop activeWindow) draw: (labelWidget copy label: 'Hello, World!').</syntaxhighlight>
 
इस स्थिति में<code>डेस्कटॉप सक्रियविंडो</code>पहले किया जाता है, [[सक्रिय खिड़की]] को विंडोज़ की सूची से लौटाता है जिसके बारे में डेस्कटॉप वस्तु जानता है। अगला (आंतरिक से बाहरी, बाएं से दाएं पढ़ें) जिस संकेत की हमने पहले जांच की थी वह लेबलविजेट लौटाता है। अंत में विजेट को सक्रिय विंडो के ड्रॉ स्लॉट में भेजा जाता है।


इस स्थिति  में<code>(desktop activeWindow)</code>पहले किया जाता है, [[सक्रिय खिड़की]] को विंडोज़ की सूची से लौटाता है जिसके बारे में डेस्कटॉप वस्तु जानता है। अगला (आंतरिक से बाहरी, बाएं से दाएं पढ़ें) जिस कोड की हमने पहले जांच की थी वह लेबलविजेट लौटाता है। अंत में विजेट को सक्रिय विंडो के ड्रॉ स्लॉट में भेजा जाता है।
[[Category:1987 में बनाई गई प्रोग्रामिंग लैंग्वेज|Self (Programming Language)]]
[[Category:1987 सॉफ्टवेयर|Self (Programming Language)]]
[[Category:All articles with dead external links|Self (Programming Language)]]
[[Category:Articles with dead external links from June 2016|Self (Programming Language)]]
[[Category:Articles with hatnote templates targeting a nonexistent page|Self (Programming Language)]]
[[Category:Collapse templates|Self (Programming Language)]]
[[Category:Created On 17/02/2023|Self (Programming Language)]]
[[Category:Machine Translated Page|Self (Programming Language)]]
[[Category:Navigational boxes| ]]
[[Category:Navigational boxes without horizontal lists|Self (Programming Language)]]
[[Category:Official website not in Wikidata|Self (Programming Language)]]
[[Category:Pages with script errors|Self (Programming Language)]]
[[Category:Sidebars with styles needing conversion|Self (Programming Language)]]
[[Category:Template documentation pages|Documentation/doc]]
[[Category:Templates Vigyan Ready|Self (Programming Language)]]
[[Category:Templates generating microformats|Self (Programming Language)]]
[[Category:Templates that are not mobile friendly|Self (Programming Language)]]
[[Category:Templates using TemplateData|Self (Programming Language)]]
[[Category:Wikipedia metatemplates|Self (Programming Language)]]
[[Category:क्रॉस-प्लेटफॉर्म मुफ्त सॉफ्टवेयर|Self (Programming Language)]]
[[Category:गतिशील प्रोग्रामिंग भाषाएँ|Self (Programming Language)]]
[[Category:गतिशील रूप से टाइप की गई प्रोग्रामिंग भाषाएँ|Self (Programming Language)]]
[[Category:निःशुल्क संकलक और दुभाषिए|Self (Programming Language)]]
[[Category:प्रोग्रामिंग भाषा|Self (Programming Language)]]
[[Category:प्रोटोटाइप-आधारित प्रोग्रामिंग भाषाएँ|Self (Programming Language)]]
[[Category:वस्तु-उन्मुख प्रोग्रामिंग भाषाएँ|Self (Programming Language)]]


=== प्रतिनिधिमंडल ===
=== प्रतिनिधिमंडल ===
{{main|Delegation (object-oriented programming)}}
सिद्धांत रूप में प्रत्येक आत्म वस्तु एक अकेली इकाई है। सेल्फ के पास न तो कक्षाएं हैं और न ही मेटा-कक्षाएं। किसी विशेष वस्तु में परिवर्तन किसी अन्य को प्रभावित नहीं करते हैं लेकिन कुछ स्थितियो  में यह वांछनीय है यदि उन्होंने ऐसा किया हो। प्राय: एक वस्तु केवल अपने स्थानीय स्लॉट से संबंधित संदेशों को समझ सकती है लेकिन मूल वस्तुओं को इंगित करने वाले एक या एक से अधिक स्लॉट होने से वस्तु किसी भी संदेश को 'प्रतिनिधि' कर सकता है जो खुद को मूल वस्तु को नहीं समझता है। प्रत्यय के रूप में एक तारांकन चिह्न जोड़कर किसी भी स्लॉट को मूल सूचक बनाया जा सकता है। इस तरह सेल्फ कर्तव्यों को संभालता है जो कक्षा-आधारित भाषाओं में विरासत (कंप्यूटर विज्ञान) का उपयोग करेगा। प्रतिनिधि मंडल का उपयोग [[नाम स्थान]] और [[लेक्सिकल स्कूपिंग]] जैसी सुविधाओं को लागू करने के लिए भी किया जा सकता है।
सिद्धांत रूप में प्रत्येक आत्म वस्तु एक अकेली इकाई है। स्वयं के पास न तो कक्षाएं हैं और न ही मेटा-क्लासेस। किसी विशेष वस्तु में परिवर्तन किसी अन्य को प्रभावित नहीं करते हैं लेकिन कुछ स्थितियो  में यह वांछनीय है यदि उन्होंने ऐसा किया हो। प्राय: एक वस्तु केवल अपने स्थानीय स्लॉट से संबंधित संदेशों को समझ सकती है लेकिन मूल वस्तुओं को इंगित करने वाले एक या एक से अधिक स्लॉट होने से वस्तु किसी भी संदेश को 'प्रतिनिधि' कर सकता है जो खुद को मूल वस्तु को नहीं समझता है। प्रत्यय के रूप में एक तारांकन चिह्न जोड़कर किसी भी स्लॉट को मूल सूचक बनाया जा सकता है। इस तरह स्वयं कर्तव्यों को संभालता है जो कक्षा-आधारित भाषाओं में विरासत (कंप्यूटर विज्ञान) का उपयोग करेगा। प्रतिनिधि मंडल का उपयोग [[नाम स्थान]] और [[लेक्सिकल स्कूपिंग]] जैसी सुविधाओं को लागू करने के लिए भी किया जा सकता है।


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


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


यह पारंपरिक वर्ग से कैसे भिन्न है? अच्छी तरह से अर्थ पर विचार करें:
यह पारंपरिक वर्ग से कैसे भिन्न है? अच्छी तरह से अर्थ पर विचार करें:


<syntaxhighlight lang= smalltalk >myObject जनक: someOtherObject.</syntaxhighlight>
<syntaxhighlight lang="smalltalk">myObject parent: someOtherObject.</syntaxhighlight>


यह अंश 'पैरेंट *' स्लॉट से जुड़े मान को बदलकर myObject की कक्षा को क्रम पर बदलता है (तारांकन स्लॉट नाम का हिस्सा है, लेकिन संबंधित संदेश नहीं)। विरासत या लेक्सिकल स्कूपिंग के विपरीत, प्रतिनिधि वस्तु को क्रम पर संशोधित किया जा सकता है।
यह अंश 'पैरेंट *' स्लॉट से जुड़े मान को बदलकर myObject की कक्षा को क्रम पर बदलता है (तारांकन स्लॉट नाम का हिस्सा है, लेकिन संबंधित संदेश नहीं)। विरासत या लेक्सिकल स्कूपिंग के विपरीत, प्रतिनिधि वस्तु को क्रम पर संशोधित किया जा सकता है।
[[Category:1987 में बनाई गई प्रोग्रामिंग लैंग्वेज|Self (Programming Language)]]
[[Category:1987 सॉफ्टवेयर|Self (Programming Language)]]
[[Category:All articles with dead external links|Self (Programming Language)]]
[[Category:Articles with dead external links from June 2016|Self (Programming Language)]]
[[Category:Articles with hatnote templates targeting a nonexistent page|Self (Programming Language)]]
[[Category:Collapse templates|Self (Programming Language)]]
[[Category:Created On 17/02/2023|Self (Programming Language)]]
[[Category:Machine Translated Page|Self (Programming Language)]]
[[Category:Navigational boxes| ]]
[[Category:Navigational boxes without horizontal lists|Self (Programming Language)]]
[[Category:Official website not in Wikidata|Self (Programming Language)]]
[[Category:Pages with script errors|Self (Programming Language)]]
[[Category:Sidebars with styles needing conversion|Self (Programming Language)]]
[[Category:Template documentation pages|Documentation/doc]]
[[Category:Templates Vigyan Ready|Self (Programming Language)]]
[[Category:Templates generating microformats|Self (Programming Language)]]
[[Category:Templates that are not mobile friendly|Self (Programming Language)]]
[[Category:Templates using TemplateData|Self (Programming Language)]]
[[Category:Wikipedia metatemplates|Self (Programming Language)]]
[[Category:क्रॉस-प्लेटफॉर्म मुफ्त सॉफ्टवेयर|Self (Programming Language)]]
[[Category:गतिशील प्रोग्रामिंग भाषाएँ|Self (Programming Language)]]
[[Category:गतिशील रूप से टाइप की गई प्रोग्रामिंग भाषाएँ|Self (Programming Language)]]
[[Category:निःशुल्क संकलक और दुभाषिए|Self (Programming Language)]]
[[Category:प्रोग्रामिंग भाषा|Self (Programming Language)]]
[[Category:प्रोटोटाइप-आधारित प्रोग्रामिंग भाषाएँ|Self (Programming Language)]]
[[Category:वस्तु-उन्मुख प्रोग्रामिंग भाषाएँ|Self (Programming Language)]]


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


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


<syntaxhighlight lang= smalltalk >_AddSlots: (| वाहन <- (|जनक* = लक्षण क्लोन करने योग्य|) |)</syntaxhighlight>
<syntaxhighlight lang="smalltalk">_AddSlots: (| vehicle <- (|parent* = traits clonable|) |).</syntaxhighlight>


चूंकि 'AddSlots' प्राचीन का रिसीवर इंगित नहीं किया गया है, यह स्वयं है। तत्पर पर टाइप किए गए भावों के स्थिति में वह एक वस्तु है जिसे लॉबी कहा जाता है। 'AddSlots' के लिए तर्क वह वस्तु है जिसके स्लॉट रिसीवर को कॉपी किए जाएंगे। इस स्थिति में यह बिल्कुल एक स्लॉट के साथ एक शाब्दिक वस्तु है। स्लॉट का नाम 'वाहन' है और इसका मूल्य एक अन्य शाब्दिक वस्तु है। <- संकेतन का तात्पर्य 'वाहन' नामक एक दूसरे स्लॉट से है, जिसका उपयोग पहले स्लॉट के मान को बदलने के लिए किया जा सकता है।
चूंकि 'AddSlots' प्राचीन का रिसीवर इंगित नहीं किया गया है, यह सेल्फ है। तत्पर पर टाइप किए गए भावों के स्थिति में वह एक वस्तु है जिसे लॉबी कहा जाता है। 'AddSlots' के लिए तर्क वह वस्तु है जिसके स्लॉट रिसीवर को कॉपी किए जाएंगे। इस स्थिति में यह बिल्कुल एक स्लॉट के साथ एक शाब्दिक वस्तु है। स्लॉट का नाम 'वाहन' है और इसका मूल्य एक अन्य शाब्दिक वस्तु है। <- संकेतन का तात्पर्य 'वाहन' नामक एक दूसरे स्लॉट से है जिसका उपयोग पहले स्लॉट के मान को बदलने के लिए किया जा सकता है।


= एक स्थिर स्लॉट इंगित करता है इसलिए कोई संबंधित 'पैरेंट' नहीं है। शाब्दिक वस्तु जो 'वाहन' का प्रारंभिक मूल्य है और उसमें एक स्लॉट सम्मिलित है ताकि यह क्लोनिंग से संबंधित संदेशों को समझ सके। वास्तव में खाली वस्तु जिसे (| |) या अधिक सरल रूप से () के रूप में दर्शाया गया है और कोई भी संदेश प्राप्त नहीं कर सकता है।
= एक स्थिर स्लॉट इंगित करता है इसलिए कोई संबंधित 'पैरेंट' नहीं है। शाब्दिक वस्तु जो 'वाहन' का प्रारंभिक मूल्य है और उसमें एक स्लॉट सम्मिलित है ताकि यह क्लोनिंग से संबंधित संदेशों को समझ सके। वास्तव में खाली वस्तु जिसे (| |) या अधिक सरल रूप से () के रूप में दर्शाया गया है और कोई भी संदेश प्राप्त नहीं कर सकता है।


<syntaxhighlight lang= smallTalk>वाहन _AddSlots: (| नाम <- 'ऑटोमोबाइल'|)</syntaxhighlight>
<syntaxhighlight lang="smalltalk">vehicle _AddSlots: (| name <- 'automobile'|).</syntaxhighlight>


यहां रिसीवर पिछली वस्तु है, जिसमें अब 'पैरेंट*के अलावा 'नाम' और 'नाम:' स्लॉट सम्मिलित होंगे।
यहां रिसीवर पिछली वस्तु है, जिसमें अब 'पैरेंट*के अतिरिक्त  'नाम' और 'नाम:' स्लॉट सम्मिलित होंगे।


<syntaxhighlight lang="smalltalk">_ AddSlots: ( | स्पोर्ट्सकार  <- वाहन  कॉपी  | )
<syntaxhighlight lang="smalltalk">_AddSlots: (| sportsCar <- vehicle copy |).
sportsCar _ AddSlots: ( | driveToWork = ( '' कुछ  कोड, यह  एक तरीका है  '' ) | ) </syntaxhighlight>
sportsCar _AddSlots: (| driveToWork = (''some code, this is a method'') |).</syntaxhighlight>


हालांकि पहले 'वाहन' और 'स्पोर्ट्सकार' बिल्कुल एक जैसे थे, अब बाद वाले में एक नया स्लॉट सम्मिलित है जिसमें एक विधि है जो मूल में नहीं है। विधियों को केवल निरंतर स्लॉट में सम्मिलित किया जा सकता है।
हालांकि पहले 'वाहन' और 'स्पोर्ट्सकार' बिल्कुल एक जैसे थे, अब बाद वाले में एक नया स्लॉट सम्मिलित है जिसमें एक विधि है जो मूल में नहीं है। विधियों को केवल निरंतर स्लॉट में सम्मिलित किया जा सकता है।


<syntaxhighlight lang= smalltalk >_AddSlots: (| porsche911 <- sportsCar copy |)
<syntaxhighlight lang="smalltalk">_AddSlots: (| porsche911 <- sportsCar copy |).
पोर्श911 नाम:'बॉब्स पोर्श'</syntaxhighlight>
porsche911 name:'Bobs Porsche'.</syntaxhighlight>
नई वस्तु 'पोर्शे911' बिल्कुल 'स्पोर्ट्सकार' की तरह शुरू हुई लेकिन अंतिम संदेश ने इसके 'नाम' स्लॉट का मान बदल दिया। ध्यान दें कि दोनों में अभी भी समान स्लॉट हैं भले ही उनमें से एक का मान भिन्न हो।


नई वस्तु 'पोर्शे911' बिल्कुल 'स्पोर्ट्सकार' की तरह शुरू हुई लेकिन अंतिम संदेश ने इसके 'नाम' स्लॉट का मान बदल दिया। ध्यान दें कि दोनों में अभी भी समान स्लॉट हैं भले ही उनमें से एक का मान भिन्न हो।
[[Category:1987 में बनाई गई प्रोग्रामिंग लैंग्वेज|Self (Programming Language)]]
[[Category:1987 सॉफ्टवेयर|Self (Programming Language)]]
[[Category:All articles with dead external links|Self (Programming Language)]]
[[Category:Articles with dead external links from June 2016|Self (Programming Language)]]
[[Category:Articles with hatnote templates targeting a nonexistent page|Self (Programming Language)]]
[[Category:Collapse templates|Self (Programming Language)]]
[[Category:Created On 17/02/2023|Self (Programming Language)]]
[[Category:Machine Translated Page|Self (Programming Language)]]
[[Category:Navigational boxes| ]]
[[Category:Navigational boxes without horizontal lists|Self (Programming Language)]]
[[Category:Official website not in Wikidata|Self (Programming Language)]]
[[Category:Pages with script errors|Self (Programming Language)]]
[[Category:Sidebars with styles needing conversion|Self (Programming Language)]]
[[Category:Template documentation pages|Documentation/doc]]
[[Category:Templates Vigyan Ready|Self (Programming Language)]]
[[Category:Templates generating microformats|Self (Programming Language)]]
[[Category:Templates that are not mobile friendly|Self (Programming Language)]]
[[Category:Templates using TemplateData|Self (Programming Language)]]
[[Category:Wikipedia metatemplates|Self (Programming Language)]]
[[Category:क्रॉस-प्लेटफॉर्म मुफ्त सॉफ्टवेयर|Self (Programming Language)]]
[[Category:गतिशील प्रोग्रामिंग भाषाएँ|Self (Programming Language)]]
[[Category:गतिशील रूप से टाइप की गई प्रोग्रामिंग भाषाएँ|Self (Programming Language)]]
[[Category:निःशुल्क संकलक और दुभाषिए|Self (Programming Language)]]
[[Category:प्रोग्रामिंग भाषा|Self (Programming Language)]]
[[Category:प्रोटोटाइप-आधारित प्रोग्रामिंग भाषाएँ|Self (Programming Language)]]
[[Category:वस्तु-उन्मुख प्रोग्रामिंग भाषाएँ|Self (Programming Language)]]


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


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


=== प्रदर्शन ===
=== प्रदर्शन ===
स्वयं वीएम ने कुछ बेंचमार्क पर अनुकूलित सी की लगभग आधी गति का प्रदर्शन हासिल किया।<ref>{{cite web |url=http://research.sun.com/jtech/pubs/97-pep.ps |title=Design and Implementation of Pep, a Java Just-In-Time Translator |last1=Agesen |first1=Ole |date=March 1997 |website=sun.com |archive-url=https://web.archive.org/web/20061124224739/http://research.sun.com/jtech/pubs/97-pep.ps |archive-date=November 24, 2006 }}</ref>यह समय-समय पर संकलन तकनीकों द्वारा हासिल किया गया था जो एक उच्च स्तरीय भाषा को अच्छी तरह से प्रदर्शन करने के लिए स्व-अनुसंधान में प्रमुख और बेहतर थे।
सेल्फ वीएम ने कुछ बेंचमार्क पर अनुकूलित सी की लगभग आधी गति का प्रदर्शन जारी किया।<ref>{{cite web |url=http://research.sun.com/jtech/pubs/97-pep.ps |title=Design and Implementation of Pep, a Java Just-In-Time Translator |last1=Agesen |first1=Ole |date=March 1997 |website=sun.com |archive-url=https://web.archive.org/web/20061124224739/http://research.sun.com/jtech/pubs/97-pep.ps |archive-date=November 24, 2006 }}</ref>यह समय-समय पर संकलन तकनीकों द्वारा उपलब्ध किया गया था जो एक उच्च स्तरीय भाषा को अच्छी तरह से प्रदर्शन करने के लिए स्व-अनुसंधान में प्रमुख और बेहतर थे।


=== कचरा संग्रह ===
=== कचरा संग्रह ===
स्वयं के लिए कचरा संग्रहकर्ता जनरेशनल कचरा संग्रह का उपयोग करता है जो उम्र के अनुसार वस्तुओं को अलग करता है। पृष्ठ लिखने के लिए स्मृति प्रबंधन प्रणाली का उपयोग करके एक राइट-बैरियर को बनाए रखा जा सकता है। यह तकनीक उत्कृष्ट प्रदर्शन देती है हालाँकि कुछ समय चलने के बाद एक पूर्ण कचरा संग्रह हो सकता है जिसमें काफी समय लगता है। <sup>[ ''अस्पष्ट'' ]</sup>
सेल्फ के लिए कचरा संग्रहकर्ता जनरेशनल कचरा संग्रह का उपयोग करता है जो उम्र के अनुसार वस्तुओं को अलग करता है। पृष्ठ लिखने के लिए स्मृति प्रबंधन प्रणाली का उपयोग करके एक राइट-बैरियर को बनाए रखा जा सकता है। यह तकनीक उत्कृष्ट प्रदर्शन देती है हालाँकि कुछ समय चलने के बाद एक पूर्ण कचरा संग्रह हो सकता है जिसमें काफी समय लगता है। <sup>[ ''अस्पष्ट'' ]</sup>
=== अनुकूलन ===
=== अनुकूलन ===
रन टाइम सिस्टम चुनिंदा रूप से कॉल स्ट्रक्चर्स को समतल करता है। यह अपने आप में मामूली स्पीडअप देता है, लेकिन विभिन्न कॉलर प्रकारों के लिए प्रकार की जानकारी के व्यापक कैशिंग और कोड के कई संस्करणों की अनुमति देता है। यह कई विधि लुकअप करने की आवश्यकता को हटा देता है और सशर्त शाखा विवरण और हार्ड-कोडेड कॉल डालने की अनुमति देता है- अक्सर भाषा स्तर पर सामान्यता के नुकसान के साथ सी-जैसा प्रदर्शन देता है, लेकिन पूरी तरह से कचरा संग्रहण प्रणाली पर।<ref>[http://www.sunlabs.com/research/self/papers/chambers-thesis/thesis.ps.Z ] {{dead link|date=June 2016|bot=medic}}{{cbignore|bot=medic}}</ref>
रन टाइम प्रणाली चुनिंदा रूप से कॉल संरचनाएं को समतल करता है। यह अपने आप में कुछ गति बढ़ा देता है लेकिन विभिन्न कॉलर प्रकारों के लिए प्रकार की जानकारी के व्यापक कैशिंग और संकेत के कई संस्करणों की अनुमति देता है। यह कई विधि लुकअप करने की आवश्यकता को हटा देता है और सशर्त शाखा विवरण और हार्ड-संकेत कॉल डालने की अनुमति देता है- अक्सर भाषा स्तर पर सामान्यता के नुकसान के साथ सी-जैसा प्रदर्शन देता है लेकिन पूरी तरह से कचरा संग्रहण प्रणाली पर।<ref>[http://www.sunlabs.com/research/self/papers/chambers-thesis/thesis.ps.Z ] {{dead link|date=June 2016|bot=medic}}{{cbignore|bot=medic}}</ref>




Line 172: Line 258:


==अग्रिम पठन==
==अग्रिम पठन==
* [http://bibliography.selflanguage.org/ Published papers on स्वयं]
* [http://bibliography.selflanguage.org/ Published papers on सेल्फ]
*{{citation
*{{citation
  | first1= C. |last1= Chambers
  | first1= C. |last1= Chambers
Line 180: Line 266:
  | publisher=[[Stanford University]]
  | publisher=[[Stanford University]]
}}
}}
* [http://blog.rfox.eu/en/Programming/Series_about_Self.html Series of four articles "Environment and the programming language स्वयं"]
* [http://blog.rfox.eu/en/Programming/Series_about_Self.html Series of four articles "Environment and the programming language सेल्फ"]




==बाहरी संबंध==
==बाहरी संबंध==
{{बाहरी संबंध|date=August 2013}}
 
* {{Official website|www.selflanguage.org}}
* {{Official website|www.selflanguage.org}}
* {{github|russellallen/self}}
* {{github|russellallen/self}}
* [https://web.archive.org/web/20020606124955/http://research.sun.com/self/ Former स्वयं Home Page at Sun Microsystems]
* [https://web.archive.org/web/20020606124955/http://research.sun.com/self/ Former सेल्फ Home Page at Sun Microsystems]
* [https://web.archive.org/web/20070503053204/http://www.cs.ucsb.edu/~urs/oocsb/self/papers/papers.html Alternate source of papers on स्वयं from UCSB (mirror for the Sun papers page)]
* [https://web.archive.org/web/20070503053204/http://www.cs.ucsb.edu/~urs/oocsb/self/papers/papers.html Alternate source of papers on सेल्फ from UCSB (mirror for the Sun papers page)]
* [https://web.archive.org/web/20050427111747/http://www.merlintec.com/lsi/ Merlin Project]
* [https://web.archive.org/web/20050427111747/http://www.merlintec.com/lsi/ Merlin Project]
* [https://web.archive.org/web/20030613141004/http://gliebe.de/self/index.html स्वयं ported to Linux (without many optimizations)]
* [https://web.archive.org/web/20030613141004/http://gliebe.de/self/index.html सेल्फ ported to Linux (without many optimizations)]
* [http://selfguru.sourceforge.net/ Automated Refactoring application on sourceforge.net, written for and in स्वयं]
* [http://selfguru.sourceforge.net/ Automated Refactoring application on sourceforge.net, written for and in सेल्फ]
* [http://www.self-support.com/ Gordon's Page on स्वयं]
* [http://www.self-support.com/ Gordon's Page on सेल्फ]
* [http://community.schemewiki.org/?prometheus Prometheus object system on the Community Scheme Wiki]
* [http://community.schemewiki.org/?prometheus Prometheus object system on the Community Scheme Wiki]
* [https://web.archive.org/web/20060813135539/http://www.smalltalk.org.br/movies/ Video demonstrating स्वयं]
* [https://web.archive.org/web/20060813135539/http://www.smalltalk.org.br/movies/ Video demonstrating सेल्फ]
* [http://www.ag-nbi.de/research/dself/ dस्वयं: distributed extension to the delegation and language स्वयं]
* [http://www.ag-nbi.de/research/dself/ dसेल्फ: distributed extension to the delegation and language सेल्फ]


{{Smalltalk programming language}}
{{Smalltalk programming language}}


{{DEFAULTSORT:Self (Programming Language)}}[[Category: प्रोग्रामिंग भाषा]] [[Category: गतिशील प्रोग्रामिंग भाषाएँ]] [[Category: गतिशील रूप से टाइप की गई प्रोग्रामिंग भाषाएँ]] [[Category: वस्तु-उन्मुख प्रोग्रामिंग भाषाएँ]] [[Category: प्रोटोटाइप-आधारित प्रोग्रामिंग भाषाएँ]] [[Category: क्रॉस-प्लेटफॉर्म मुफ्त सॉफ्टवेयर]] [[Category: निःशुल्क संकलक और दुभाषिए]] [[Category: 1987 में बनाई गई प्रोग्रामिंग लैंग्वेज]] [[Category: 1987 सॉफ्टवेयर]]
{{DEFAULTSORT:Self (Programming Language)}}
 
 


[[Category: Machine Translated Page]]
[[Category:1987 में बनाई गई प्रोग्रामिंग लैंग्वेज|Self (Programming Language)]]
[[Category:Created On 17/02/2023]]
[[Category:1987 सॉफ्टवेयर|Self (Programming Language)]]
[[Category:All articles with dead external links|Self (Programming Language)]]
[[Category:Articles with dead external links from June 2016|Self (Programming Language)]]
[[Category:Articles with hatnote templates targeting a nonexistent page|Self (Programming Language)]]
[[Category:Collapse templates|Self (Programming Language)]]
[[Category:Created On 17/02/2023|Self (Programming Language)]]
[[Category:Machine Translated Page|Self (Programming Language)]]
[[Category:Navigational boxes| ]]
[[Category:Navigational boxes without horizontal lists|Self (Programming Language)]]
[[Category:Official website not in Wikidata|Self (Programming Language)]]
[[Category:Pages with script errors|Self (Programming Language)]]
[[Category:Sidebars with styles needing conversion|Self (Programming Language)]]
[[Category:Template documentation pages|Documentation/doc]]
[[Category:Templates Vigyan Ready|Self (Programming Language)]]
[[Category:Templates generating microformats|Self (Programming Language)]]
[[Category:Templates that are not mobile friendly|Self (Programming Language)]]
[[Category:Templates using TemplateData|Self (Programming Language)]]
[[Category:Wikipedia metatemplates|Self (Programming Language)]]
[[Category:क्रॉस-प्लेटफॉर्म मुफ्त सॉफ्टवेयर|Self (Programming Language)]]
[[Category:गतिशील प्रोग्रामिंग भाषाएँ|Self (Programming Language)]]
[[Category:गतिशील रूप से टाइप की गई प्रोग्रामिंग भाषाएँ|Self (Programming Language)]]
[[Category:निःशुल्क संकलक और दुभाषिए|Self (Programming Language)]]
[[Category:प्रोग्रामिंग भाषा|Self (Programming Language)]]
[[Category:प्रोटोटाइप-आधारित प्रोग्रामिंग भाषाएँ|Self (Programming Language)]]
[[Category:वस्तु-उन्मुख प्रोग्रामिंग भाषाएँ|Self (Programming Language)]]

Latest revision as of 13:24, 15 September 2023

सेल्फ एक वस्तु-उन्मुख प्रोग्रामिंग भाषा है जो प्रोटोटाइप-आधारित प्रोग्रामिंग की अवधारणा पर आधारित है। सेल्फ की शुरुआत स्मॉलटाक की एक बोली के रूप में हुई, जिसे गतिशील रूप से टाइप किया गया और समय-समय पर संकलन (JIT) के साथ-साथ वस्तुओं के लिए प्रोटोटाइप-आधारित दृष्टिकोण का उपयोग किया गया। यह पहली बार 1980 और 1990 के दशक में भाषा बनाने के लिए एक प्रायोगिक परीक्षण प्रणाली के रूप में उपयोग किया गया था। 2006 में सेल्फ अभी भी क्लेन प्रोजेक्ट के हिस्से के रूप में विकसित किया जा रहा था जो सेल्फ आभासी मशीन थी जो पूरी तरह से सेल्फ में लिखी गई थी। नवीनतम संस्करण 1 मई 2017 में जारी किया गया है।[1]

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

एक बिंदु पर स्मालटाक का एक संस्करण सेल्फ में लागू किया गया था। क्योंकि यह समय-समय पर संकलन (JIT) का उपयोग करने में सक्षम था और इसने भी बहुत अच्छा प्रदर्शन दिया।[2]

इतिहास

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

पहली सार्वजनिक रिलीज़ 1990 में हुई थी और अगले साल टीम सन माइक्रोप्रणाली में चली गई जहाँ उन्होंने भाषा पर काम जारी रखा। 1995 में 4.0 संस्करण के साथ बड़े पैमाने पर निष्क्रिय होने तक कई नए रिलीज़ हुए। 4.3 संस्करण 2006 में जारी किया गया था और मैक ओएसएक्स और सोलारिस पर चलता था। 2010 में एक नई रिलीज,[3] संस्करण 4.4 एक समूह द्वारा विकसित किया गया है जिसमें कुछ मूल टीम और स्वतंत्र प्रोग्रामर सम्मिलित हैं और यह मैक ओएस एक्स और लिनक्स के लिए उपलब्ध है जैसा कि निम्नलिखित सभी संस्करण हैं। अनुवर्ती 4.5 जनवरी 2014 में[4] और तीन साल बाद संस्करण 1 मई 2017 में जारी किया गया था।

मॉर्फिक (सॉफ्टवेयर) मूल रूप से सेल्फ प्रोग्रामिंग भाषा के लिए रैंडी स्मिथ और जॉन मैलोनी द्वारा विकसित किया गया था।[5] मॉर्फिक को चीख़, जावास्क्रिप्ट, पायथन (प्रोग्रामिंग भाषा) और उद्देश्य सी सहित अन्य उल्लेखनीय आईओ प्रोग्रामिंग भाषा पोर्ट किया गया है।

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

प्रोटोटाइप-आधारित प्रोग्रामिंग भाषा

पारंपरिक वर्ग-आधारित ओओ भाषाएँ एक गहरी जड़ वाले द्वैत पर आधारित हैं

  1. कक्षाएं वस्तुओं के मूल गुणों और व्यवहारों को परिभाषित करती हैं।
  2. वस्तु उदाहरण एक वर्ग की विशेष अभिव्यक्तियाँ हैं।

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

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

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

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

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

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

विवरण

सेल्फ वस्तु स्लॉट्स का एक संग्रह है। स्लॉट एक्सेसर विधियाँ हैं जो मान लौटाती हैं और स्लॉट के नाम के बाद एक कोलन रखने से मान सेट हो जाता है। उदाहरण के लिए नाम नामक स्लॉट के लिए

myPerson name

returns the value in name, and

myPerson name:'foo'

इसे सेट करता है।

सेल्फ स्मॉलटॉक की तरह प्रवाह नियंत्रण और अन्य कर्तव्यों के लिए ब्लॉक का उपयोग करता है। विधियाँ ऐसी वस्तुएँ हैं जिनमें स्लॉट्स के अतिरिक्त संकेत होते है (जो वे तर्कों और अस्थायी मानों के लिए उपयोग करते हैं) और किसी अन्य वस्तु की तरह ही सेल्फ स्लॉट में रखा जा सकता है: उदाहरण के लिए एक संख्या। वाक्य - विन्यास दोनों ही स्थितियो में समान रहता है।

ध्यान दें कि सेल्फ में फ़ील्ड और विधियों के बीच कोई अंतर नहीं है: सब कुछ एक स्लॉट है। संदेशों के माध्यम से स्लॉट तक पहुँचने के बाद से सेल्फ में वाक्य - विन्यास का अधिकांश भाग बनता है, कई संदेश सेल्फ को भेजे जाते हैं और सेल्फ को छोड़ा जा सकता है।

बेसिक वाक्य - विन्यास

स्लॉट तक पहुँचने के लिए वाक्य - विन्यास स्मॉलटाक के समान है। तीन प्रकार के संदेश उपलब्ध हैं:

unary
receiver slot_name
binary
receiver + argument
keyword
receiver keyword: arg1 With: arg2

सभी संदेश परिणाम लौटाते हैं इसलिए रिसीवर (यदि स्थित है) और तर्क सेल्फ अन्य संदेशों का परिणाम हो सकते हैं। एक अवधि के बाद एक संदेश का मतलब है कि सेल्फ लौटाए गए मान को त्याग देगा। उदाहरण के लिए:

'Hello, World!' print.

यह हैलो वर्ल्ड प्रोग्राम का सेल्फ वर्जन है । सिंटैक्स 'एक शाब्दिक स्ट्रिंग ऑब्जेक्ट को इंगित करता है। अन्य शाब्दिक में संख्याएँ, ब्लॉक और सामान्य वस्तुएँ सम्मिलित हैं।

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

मान्य:  आधार  तल

     

valid: base bottom
          between: ligature bottom + height
          And: base top / scale factor.

स्पष्ट रूप से पार्स किया जा सकता है और इसका मतलब वही है:

valid: ((base bottom)
            between: ((ligature bottom) + height)
            And: ((base top) / (scale factor))).


स्मॉलटाक -80 में समान अभिव्यक्ति को इस प्रकार लिखा जाएगा:

valid := self base bottom
             between: self ligature bottom + self height
             and: self base top / self scale factor.

मान लिया जायेबेस,लिगेचर,ऊंचाईऔरस्केलके उदाहरण चर नहीं थे सेल्फलेकिन वास्तव में तरीके थे।

नई वस्तुएं बनाना

थोड़ा और जटिल उदाहरण पर विचार करें:

labelWidget copy label: 'Hello, World!'.

कॉपी संदेश के साथ लेबलविजेट वस्तु की प्रतिलिपि बनाता है (इस बार कोई शॉर्टकट नहीं है), फिर इसे लेबल नामक स्लॉट में हैलो वर्ल्ड डालने के लिए एक संदेश भेजता है। अब इसके साथ कुछ करना है:

(desktop activeWindow) draw: (labelWidget copy label: 'Hello, World!').

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

प्रतिनिधिमंडल

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

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

लक्षण

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

इस उदाहरण में बैंक खाते की वस्तु में जमा और निकासी की विधि नहीं होगी लेकिन माता-पिता के रूप में एक वस्तु होगी। इस तरह से बैंक खाते वस्तु की कई प्रतियाँ बनाई जा सकती हैं लेकिन फिर भी हम उस रूट वस्तु में स्लॉट्स को बदलकर उन सभी के व्यवहार को बदल सकते हैं।

यह पारंपरिक वर्ग से कैसे भिन्न है? अच्छी तरह से अर्थ पर विचार करें:

myObject parent: someOtherObject.

यह अंश 'पैरेंट *' स्लॉट से जुड़े मान को बदलकर myObject की कक्षा को क्रम पर बदलता है (तारांकन स्लॉट नाम का हिस्सा है, लेकिन संबंधित संदेश नहीं)। विरासत या लेक्सिकल स्कूपिंग के विपरीत, प्रतिनिधि वस्तु को क्रम पर संशोधित किया जा सकता है।

स्लॉट जोड़ना

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

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

_AddSlots: (| vehicle <- (|parent* = traits clonable|) |).

चूंकि 'AddSlots' प्राचीन का रिसीवर इंगित नहीं किया गया है, यह सेल्फ है। तत्पर पर टाइप किए गए भावों के स्थिति में वह एक वस्तु है जिसे लॉबी कहा जाता है। 'AddSlots' के लिए तर्क वह वस्तु है जिसके स्लॉट रिसीवर को कॉपी किए जाएंगे। इस स्थिति में यह बिल्कुल एक स्लॉट के साथ एक शाब्दिक वस्तु है। स्लॉट का नाम 'वाहन' है और इसका मूल्य एक अन्य शाब्दिक वस्तु है। <- संकेतन का तात्पर्य 'वाहन' नामक एक दूसरे स्लॉट से है जिसका उपयोग पहले स्लॉट के मान को बदलने के लिए किया जा सकता है।

= एक स्थिर स्लॉट इंगित करता है इसलिए कोई संबंधित 'पैरेंट' नहीं है। शाब्दिक वस्तु जो 'वाहन' का प्रारंभिक मूल्य है और उसमें एक स्लॉट सम्मिलित है ताकि यह क्लोनिंग से संबंधित संदेशों को समझ सके। वास्तव में खाली वस्तु जिसे (| |) या अधिक सरल रूप से () के रूप में दर्शाया गया है और कोई भी संदेश प्राप्त नहीं कर सकता है।

vehicle _AddSlots: (| name <- 'automobile'|).

यहां रिसीवर पिछली वस्तु है, जिसमें अब 'पैरेंट*के अतिरिक्त 'नाम' और 'नाम:' स्लॉट सम्मिलित होंगे।

_AddSlots: (| sportsCar <- vehicle copy |).
sportsCar _AddSlots: (| driveToWork = (''some code, this is a method'') |).

हालांकि पहले 'वाहन' और 'स्पोर्ट्सकार' बिल्कुल एक जैसे थे, अब बाद वाले में एक नया स्लॉट सम्मिलित है जिसमें एक विधि है जो मूल में नहीं है। विधियों को केवल निरंतर स्लॉट में सम्मिलित किया जा सकता है।

_AddSlots: (| porsche911 <- sportsCar copy |).
porsche911 name:'Bobs Porsche'.

नई वस्तु 'पोर्शे911' बिल्कुल 'स्पोर्ट्सकार' की तरह शुरू हुई लेकिन अंतिम संदेश ने इसके 'नाम' स्लॉट का मान बदल दिया। ध्यान दें कि दोनों में अभी भी समान स्लॉट हैं भले ही उनमें से एक का मान भिन्न हो।

पर्यावरण

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

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

प्रदर्शन

सेल्फ वीएम ने कुछ बेंचमार्क पर अनुकूलित सी की लगभग आधी गति का प्रदर्शन जारी किया।[6]यह समय-समय पर संकलन तकनीकों द्वारा उपलब्ध किया गया था जो एक उच्च स्तरीय भाषा को अच्छी तरह से प्रदर्शन करने के लिए स्व-अनुसंधान में प्रमुख और बेहतर थे।

कचरा संग्रह

सेल्फ के लिए कचरा संग्रहकर्ता जनरेशनल कचरा संग्रह का उपयोग करता है जो उम्र के अनुसार वस्तुओं को अलग करता है। पृष्ठ लिखने के लिए स्मृति प्रबंधन प्रणाली का उपयोग करके एक राइट-बैरियर को बनाए रखा जा सकता है। यह तकनीक उत्कृष्ट प्रदर्शन देती है हालाँकि कुछ समय चलने के बाद एक पूर्ण कचरा संग्रह हो सकता है जिसमें काफी समय लगता है। [ अस्पष्ट ]

अनुकूलन

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


यह भी देखें

संदर्भ

  1. "Self "Mandarin" 2017.1". 24 May 2017. Archived from the original on 24 May 2017. Retrieved 24 May 2017.
  2. Wolczko, Mario (1996). "self includes: Smalltalk". Workshop on Prototype-Based Languages, ECOOP '96, Linz, Austria.
  3. "Self 4.4 released". 16 July 2010. Archived from the original on 5 December 2017. Retrieved 24 May 2017.
  4. "Self Mallard (4.5.0) released". 12 January 2014. Archived from the original on 6 December 2017. Retrieved 24 May 2017.
  5. Maloney, John H.; Smith, Randall B. (1995). "Directness and Liveness in the Morphic User Interface Construction Environment". Proceedings of the 8th Annual ACM Symposium on User Interface and Software Technology: 21–28. doi:10.1145/215585.215636. ISBN 089791709X. S2CID 14479674. Retrieved 24 March 2020.
  6. Agesen, Ole (March 1997). "Design and Implementation of Pep, a Java Just-In-Time Translator". sun.com. Archived from the original on November 24, 2006.
  7. [1][dead link]


अग्रिम पठन


बाहरी संबंध