दिस (THIS कंप्यूटर प्रोग्रामिंग): Difference between revisions
m (Abhishek moved page यह (कंप्यूटर प्रोग्रामिंग) to दिस (THIS कंप्यूटर प्रोग्रामिंग) without leaving a redirect) |
No edit summary |
||
Line 4: | Line 4: | ||
अनेक [[ ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग |ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग]] भाषाओं में, <code>this</code> (यह भी कहा जाता है <code>self</code> या <code>Me</code>) वेरिएबल है जिसका उपयोग इंस्टेंस विधियों में उस ऑब्जेक्ट को संदर्भित करने के लिए किया जाता है जिस पर वह काम कर रहे हैं। पहली OO भाषा, SIMULA 67, ने <code>this</code> स्थानीय ऑब्जेक्ट को स्पष्ट रूप से संदर्भित करने के लिए इसका उपयोग किया।<ref>{{cite web |last1=Dahl |first1=Ole-Johan |author-link=Ole-Johan Dahl |last2=Myhrhaug |first2=Bjørn |last3=Nygaard |first3=Kristen |author3-link=Kristen Nygaard |date=1970 |url=http://www.edelweb.fr/Simula/#7 |title=Common Base Language, Norwegian Computing Center}}</ref>{{rp|4.3.2.3}} [[C++]] और इससे शैली में व्युत्पन्न भाषाएं (जैसे Java, C#, D और [[पीएचपी]]) भी सामान्यतः उपयोग की जाती हैं <code>this</code>. स्मॉलटॉक और अन्य, जैसे [[ऑब्जेक्ट पास्कल]], [[पर्ल]], [[पायथन (प्रोग्रामिंग भाषा)]], [[रूबी (प्रोग्रामिंग भाषा)]], रस्ट (प्रोग्रामिंग भाषा), [[ उद्देश्य सी |उद्देश्य सी]] , [[डेटाफ्लेक्स]] और [[स्विफ्ट (प्रोग्रामिंग भाषा)]], उपयोग करें <code>self</code>. माइक्रोसॉफ्ट के [[मूल दृश्य]] <code>Me</code>का उपयोग करता है। | अनेक [[ ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग |ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग]] भाषाओं में, <code>this</code> (यह भी कहा जाता है <code>self</code> या <code>Me</code>) वेरिएबल है जिसका उपयोग इंस्टेंस विधियों में उस ऑब्जेक्ट को संदर्भित करने के लिए किया जाता है जिस पर वह काम कर रहे हैं। पहली OO भाषा, SIMULA 67, ने <code>this</code> स्थानीय ऑब्जेक्ट को स्पष्ट रूप से संदर्भित करने के लिए इसका उपयोग किया।<ref>{{cite web |last1=Dahl |first1=Ole-Johan |author-link=Ole-Johan Dahl |last2=Myhrhaug |first2=Bjørn |last3=Nygaard |first3=Kristen |author3-link=Kristen Nygaard |date=1970 |url=http://www.edelweb.fr/Simula/#7 |title=Common Base Language, Norwegian Computing Center}}</ref>{{rp|4.3.2.3}} [[C++]] और इससे शैली में व्युत्पन्न भाषाएं (जैसे Java, C#, D और [[पीएचपी]]) भी सामान्यतः उपयोग की जाती हैं <code>this</code>. स्मॉलटॉक और अन्य, जैसे [[ऑब्जेक्ट पास्कल]], [[पर्ल]], [[पायथन (प्रोग्रामिंग भाषा)]], [[रूबी (प्रोग्रामिंग भाषा)]], रस्ट (प्रोग्रामिंग भाषा), [[ उद्देश्य सी |उद्देश्य सी]] , [[डेटाफ्लेक्स]] और [[स्विफ्ट (प्रोग्रामिंग भाषा)]], उपयोग करें <code>self</code>. माइक्रोसॉफ्ट के [[मूल दृश्य]] <code>Me</code>का उपयोग करता है। | ||
यह अवधारणा सभी भाषाओं में समान है: <code>this</code> सामान्यतः अपरिवर्तनीय [[संदर्भ (कंप्यूटर विज्ञान)]] या [[ सूचक (कंप्यूटर प्रोग्रामिंग) |सूचक (कंप्यूटर प्रोग्रामिंग)]] है जो वर्तमान वस्तु को संदर्भित करता है; वर्तमान ऑब्जेक्ट अधिकांशतः वह कोड होता है जो [[ संपत्ति (प्रोग्रामिंग) |संपत्ति (प्रोग्रामिंग)]] , [[ विधि (कंप्यूटर प्रोग्रामिंग) |विधि (कंप्यूटर प्रोग्रामिंग)]], सब-रूटीन या फलन के लिए '''<nowiki/>'पैरेंट'<nowiki/>''' या '''<nowiki/>'इनवॉकेंट'''' के रूप में कार्य करता है जिसमें सम्मिलित होता है <code>this</code> कीवर्ड. किसी वस्तु के ठीक से निर्माण या त्वरितीकरण के पश्चात्, <code>this</code> | यह अवधारणा सभी भाषाओं में समान है: <code>this</code> सामान्यतः अपरिवर्तनीय [[संदर्भ (कंप्यूटर विज्ञान)]] या [[ सूचक (कंप्यूटर प्रोग्रामिंग) |सूचक (कंप्यूटर प्रोग्रामिंग)]] है जो वर्तमान वस्तु को संदर्भित करता है; वर्तमान ऑब्जेक्ट अधिकांशतः वह कोड होता है जो [[ संपत्ति (प्रोग्रामिंग) |संपत्ति (प्रोग्रामिंग)]] , [[ विधि (कंप्यूटर प्रोग्रामिंग) |विधि (कंप्यूटर प्रोग्रामिंग)]], सब-रूटीन या फलन के लिए '''<nowiki/>'पैरेंट'<nowiki/>''' या '''<nowiki/>'इनवॉकेंट'''' के रूप में कार्य करता है जिसमें सम्मिलित होता है <code>this</code> कीवर्ड. किसी वस्तु के ठीक से निर्माण या त्वरितीकरण के पश्चात्, <code>this</code> सदैव वैध संदर्भ होता है. कुछ भाषाओं को स्पष्ट रूप से इसकी आवश्यकता होती है; अन्य लोग अपने वर्ग के प्रतीकों को दृश्यमान बनाने के लिए इसका अंतर्निहित रूप से उपयोग करने के लिए [[ शाब्दिक दायरा |शाब्दिक]] सीमा का उपयोग करते हैं। या वैकल्पिक रूप से, वर्तमान वस्तु द्वारा संदर्भित <code>this</code> स्वतंत्र कोड ऑब्जेक्ट हो सकता है जिसने कीवर्ड वाले फलन या विधि को कॉल किया हो <code>this</code>. ऐसी बात होती है, उदाहरण के लिए, जब किसी वेब पेज में एचटीएमएल टैग से जुड़ा [[जावास्क्रिप्ट]] ईवेंट हैंडलर कीवर्ड वाले फलन को कॉल करता है <code>this</code> दस्तावेज़ ऑब्जेक्ट के बाहर वैश्विक स्थान में संग्रहीत; उस संदर्भ में, <code>this</code> दस्तावेज़ ऑब्जेक्ट के अंदर पृष्ठ तत्व को संदर्भित करेगा, संलग्न विंडो ऑब्जेक्ट को नहीं।<ref>Powell, Thomas A, and Schneider, Fritz, 2012. ''JavaScript: The Complete Reference, Third Edition.'' McGraw-Hill. Chapter 11, ''Event Handling'', p 428. {{ISBN|978-0-07-174120-0}}</ref> | ||
कुछ भाषाओं में, उदाहरण के लिए C++, Java और Raku <code>this</code> या <code>self</code> [[कीवर्ड (कंप्यूटर प्रोग्रामिंग)]] है, और वेरिएबल स्वचालित रूप से इंस्टेंस विधियों में उपस्तिथ होता है। दूसरों में, उदाहरण के लिए पायथन, रस्ट और पर्ल 5 में, इंस्टेंस विधि का पहला पैरामीटर ऐसा संदर्भ है। इसे स्पष्ट रूप से निर्दिष्ट करने की आवश्यकता है। पायथन और पर्ल में, पैरामीटर को आवश्यक रूप से नाम देने की आवश्यकता नहीं है <code>this</code> या <code>self</code>; इसे किसी अन्य पैरामीटर की तरह प्रोग्रामर द्वारा स्वतंत्र रूप से नामित किया जा सकता है। चूँकि, अनौपचारिक परंपरा के अनुसार, पर्ल या पायथन में इंस्टेंस विधि के पहले पैरामीटर को self नाम दिया गया है। जंग के लिए स्वयं वस्तु को बुलाए जाने की आवश्यकता होती है <code>&self</code> या <code>self</code>, इस बात पर निर्भर करता है कि क्या इनवोक किया गया फलन इनवोकेंट को उधार लेता है, या उसे क्रमशः अंदर ले जाता है। | कुछ भाषाओं में, उदाहरण के लिए C++, Java और Raku <code>this</code> या <code>self</code> [[कीवर्ड (कंप्यूटर प्रोग्रामिंग)]] है, और वेरिएबल स्वचालित रूप से इंस्टेंस विधियों में उपस्तिथ होता है। दूसरों में, उदाहरण के लिए पायथन, रस्ट और पर्ल 5 में, इंस्टेंस विधि का पहला पैरामीटर ऐसा संदर्भ है। इसे स्पष्ट रूप से निर्दिष्ट करने की आवश्यकता है। पायथन और पर्ल में, पैरामीटर को आवश्यक रूप से नाम देने की आवश्यकता नहीं है <code>this</code> या <code>self</code>; इसे किसी अन्य पैरामीटर की तरह प्रोग्रामर द्वारा स्वतंत्र रूप से नामित किया जा सकता है। चूँकि, अनौपचारिक परंपरा के अनुसार, पर्ल या पायथन में इंस्टेंस विधि के पहले पैरामीटर को self नाम दिया गया है। जंग के लिए स्वयं वस्तु को बुलाए जाने की आवश्यकता होती है <code>&self</code> या <code>self</code>, इस बात पर निर्भर करता है कि क्या इनवोक किया गया फलन इनवोकेंट को उधार लेता है, या उसे क्रमशः अंदर ले जाता है। | ||
Line 36: | Line 36: | ||
यह उदाहरण कृत्रिम है, क्योंकि यह प्रत्यक्ष प्रत्यावर्तन है, इसलिए ओवरराइडिंग है फैक्टोरियल विधि इस फलन को ओवरराइड करना इस फ़ंक्शन को ओवरराइड कर देगा; अधिक प्राकृतिक उदाहरण तब होते हैं जब व्युत्पन्न वर्ग में विधि बेस क्लास में या पारस्परिक पुनरावृत्ति के स्थितियोंमें उसी विधि को कॉल करती है।<ref>"[http://www.cs.ox.ac.uk/people/ralf.hinze/talks/Open.pdf Closed and Open Recursion]", [http://www.informatik.uni-bonn.de/~ralf Ralf Hinze], July 2007</ref><ref>[http://lambda-the-ultimate.org/node/3204 Open Recursion], ''[http://lambda-the-ultimate.org/ Lambda the Ultimate]''</ref> | यह उदाहरण कृत्रिम है, क्योंकि यह प्रत्यक्ष प्रत्यावर्तन है, इसलिए ओवरराइडिंग है फैक्टोरियल विधि इस फलन को ओवरराइड करना इस फ़ंक्शन को ओवरराइड कर देगा; अधिक प्राकृतिक उदाहरण तब होते हैं जब व्युत्पन्न वर्ग में विधि बेस क्लास में या पारस्परिक पुनरावृत्ति के स्थितियोंमें उसी विधि को कॉल करती है।<ref>"[http://www.cs.ox.ac.uk/people/ralf.hinze/talks/Open.pdf Closed and Open Recursion]", [http://www.informatik.uni-bonn.de/~ralf Ralf Hinze], July 2007</ref><ref>[http://lambda-the-ultimate.org/node/3204 Open Recursion], ''[http://lambda-the-ultimate.org/ Lambda the Ultimate]''</ref> | ||
अशक्त बेस क्लास समस्या के लिए ओपन रिकर्सन को दोषी ठहराया गया है, जिसमें सुझाव दिया गया है कि प्रणाली को प्रयुक्त किया जाए <code>this</code> खुले रिकर्सन (गतिशील प्रेषण, देर से बाइंडिंग) के अतिरिक्त बंद रिकर्सन (स्थैतिक प्रेषण, प्रारंभिक बाइंडिंग) के लिए डिफ़ॉल्ट, विशेष रूप से अनुरोध किए जाने पर केवल खुले रिकर्सन का उपयोग करना; बाहरी कॉल (उपयोग नहीं कर रहे हैं <code>this</code>) | अशक्त बेस क्लास समस्या के लिए ओपन रिकर्सन को दोषी ठहराया गया है, जिसमें सुझाव दिया गया है कि प्रणाली को प्रयुक्त किया जाए <code>this</code> खुले रिकर्सन (गतिशील प्रेषण, देर से बाइंडिंग) के अतिरिक्त बंद रिकर्सन (स्थैतिक प्रेषण, प्रारंभिक बाइंडिंग) के लिए डिफ़ॉल्ट, विशेष रूप से अनुरोध किए जाने पर केवल खुले रिकर्सन का उपयोग करना; बाहरी कॉल (उपयोग नहीं कर रहे हैं <code>this</code>) सदैव की तरह गतिशील रूप से भेजा जाएगा।<ref>"[https://www.cs.cmu.edu/~aldrich/papers/selective-open-recursion.pdf Selective Open Recursion: A Solution to the Fragile Base Class Problem]", Jonathan Aldrich</ref><ref>"[http://lambda-the-ultimate.org/classic/message12271.html Selective Open Recursion: A Solution to the Fragile Base Class Problem]", ''[http://lambda-the-ultimate.org/ Lambda the Ultimate]''</ref> जिस तरह से इसे जेडीके में व्यवहार में हल किया जाता है वह निश्चित प्रोग्रामर अनुशासन के माध्यम से होता है; इस अनुशासन को सी. रूबी और जी. टी. लीवेन्स द्वारा औपचारिक रूप दिया गया है; इसमें मूल रूप से निम्नलिखित नियम सम्मिलित हैं:<ref name="JDK">Aldrich, Jonathan, and Kevin Donnelly. "[https://www.cs.cmu.edu/~aldrich/papers/savcbs04.pdf Selective open recursion: Modular reasoning about components and inheritance.]" SAVCBS 2004 Specification and Verification of Component-Based Systems (2004): 26. citing for the JDK-adopted solution C. Ruby and G. T. Leavens. "Safely Creating Correct Subclasses without Seeing Superclass Code". In Object-Oriented Programming Systems, Languages, and Applications, October 2000. {{doi|10.1145/353171.353186}} also available as [http://www.eecs.ucf.edu/~leavens/tech-reports/ISU/TR00-05/TR.pdf technical report TR #00-05d]</ref> | ||
* कोई कोड प्रयुक्त नहीं होता <code>public</code> तरीकों पर <code>this</code>. | * कोई कोड प्रयुक्त नहीं होता <code>public</code> तरीकों पर <code>this</code>. | ||
* कोड जिसे आंतरिक रूप से पुन: उपयोग किया जा सकता है (उसी वर्ग के अन्य तरीकों से आह्वान करके) में समाहित किया गया है <code>protected</code> या <code>private</code> प्रणाली; यदि इसे सीधे उपयोगकर्ताओं के सामने प्रदर्शित करने की आवश्यकता है, तब आवरण <code>public</code> विधि आंतरिक विधि को कॉल करती है। | * कोड जिसे आंतरिक रूप से पुन: उपयोग किया जा सकता है (उसी वर्ग के अन्य तरीकों से आह्वान करके) में समाहित किया गया है <code>protected</code> या <code>private</code> प्रणाली; यदि इसे सीधे उपयोगकर्ताओं के सामने प्रदर्शित करने की आवश्यकता है, तब आवरण <code>public</code> विधि आंतरिक विधि को कॉल करती है। | ||
Line 46: | Line 46: | ||
{{details|सी++ कक्षाएं}} | {{details|सी++ कक्षाएं}} | ||
C++ के प्रारंभिक संस्करण इसकी अनुमति देंगे <code>this</code> सूचक बदला जाए; ऐसा करने से प्रोग्रामर यह बदल सकता है कि कोई विधि किस ऑब्जेक्ट पर काम कर रही है। यह सुविधा अंततः हटा दी गई, और | C++ के प्रारंभिक संस्करण इसकी अनुमति देंगे <code>this</code> सूचक बदला जाए; ऐसा करने से प्रोग्रामर यह बदल सकता है कि कोई विधि किस ऑब्जेक्ट पर काम कर रही है। यह सुविधा अंततः हटा दी गई, और वर्तमान <code>this</code> C++ में वैल्यू (कंप्यूटर साइंस)#असाइनमेंट है: एल-वैल्यू और आर-वैल्यू|आर-वैल्यू।<ref name="C++03">{{cite book | ||
| year = 2003 | | year = 2003 | ||
| title = ISO/IEC 14882:2003(E): Programming Languages - C++ | | title = ISO/IEC 14882:2003(E): Programming Languages - C++ | ||
Line 58: | Line 58: | ||
=== सी === | === सी === | ||
{{details|सी शार्प (प्रोग्रामिंग भाषा)}} | {{details|सी शार्प (प्रोग्रामिंग भाषा)}} | ||
कीवर्ड <code>this</code> सी शार्प (प्रोग्रामिंग भाषा) में|सी# संदर्भ प्रकारों के लिए जावा की तरह ही काम करता है। चूँकि, C# [[मान प्रकार]] | कीवर्ड <code>this</code> सी शार्प (प्रोग्रामिंग भाषा) में|सी# संदर्भ प्रकारों के लिए जावा की तरह ही काम करता है। चूँकि, C# [[मान प्रकार]] के अंदर, <code>this</code> सामान्य परिवर्तनीय चर संदर्भ के समान होने के कारण, इसमें अधिक भिन्न शब्दार्थ हैं, और यह किसी असाइनमेंट के बाईं ओर भी हो सकता है। | ||
का प्रयोग <code>this</code> C# में विधि के | का प्रयोग <code>this</code> C# में विधि के अंदर बाहरी फ़ील्ड वैरिएबल के संदर्भ की अनुमति देना है जिसमें स्थानीय वैरिएबल होता है जिसका नाम समान होता है। ऐसी स्थिति में, उदाहरण के लिए, कथन <code>var n = localAndFieldname;</code> विधि के अंदर स्थानीय चर का प्रकार और मान निर्दिष्ट किया जाएगा <code>localAndFieldname</code> को <code>n</code>, जबकि कथन <code>var n = this.localAndFieldname;</code> बाहरी फ़ील्ड वैरिएबल का प्रकार और मान <code>n</code>निर्दिष्ट करेगा .<ref>De Smet, Bart, 2011. ''C# 4.0 Unleashed.'' Sams Publishing, Indianapolis, USA. Chapter 4, ''Language Essentials'', p 210. {{ISBN|978-0-672-33079-7}}</ref> | ||
=== डी === | === डी === | ||
डी में (प्रोग्रामिंग भाषा) <code>this</code> किसी वर्ग, संरचना या संघ विधि में संलग्न समुच्चय के उदाहरण के अपरिवर्तनीय संदर्भ को संदर्भित किया जाता है। कक्षाएं [[संदर्भ प्रकार]] के प्रकार हैं, संरचनाएं और यूनियन मूल्य प्रकार हैं। डी के पहले संस्करण में, कीवर्ड <code>this</code> उस ऑब्जेक्ट के उदाहरण के लिए सूचक के रूप में उपयोग किया जाता है जिससे विधि जुड़ी हुई है, जबकि डी 2 में इसमें संदर्भ द्वारा अंतर्निहित कॉल का चरित्र होता है |<code>ref</code>फलन तर्क. | डी में (प्रोग्रामिंग भाषा) <code>this</code> किसी वर्ग, संरचना या संघ विधि में संलग्न समुच्चय के उदाहरण के अपरिवर्तनीय संदर्भ को संदर्भित किया जाता है। कक्षाएं [[संदर्भ प्रकार]] के प्रकार हैं, संरचनाएं और यूनियन मूल्य प्रकार हैं। डी के पहले संस्करण में, कीवर्ड <code>this</code> उस ऑब्जेक्ट के उदाहरण के लिए सूचक के रूप में उपयोग किया जाता है जिससे विधि जुड़ी हुई है, जबकि डी 2 में इसमें संदर्भ द्वारा अंतर्निहित कॉल का चरित्र होता है |<code>ref</code>फलन तर्क. | ||
Line 73: | Line 73: | ||
=== एफिल === | === एफिल === | ||
एक वर्ग पाठ के | एक वर्ग पाठ के अंदर, वर्तमान प्रकार वर्तमान वर्ग से प्राप्त प्रकार है। किसी कक्षा की सुविधाओं (दिनचर्या, आदेश और प्रश्न) के अंदर, कोई कीवर्ड का उपयोग कर सकता है <code>Current</code> वर्तमान वर्ग और उसकी विशेषताओं का संदर्भ देने के लिए। कीवर्ड का उपयोग <code>Current</code> कीवर्ड के रूप में वैकल्पिक है <code>Current</code> इसका तात्पर्य केवल वर्तमान वर्ग सुविधा के नाम को खुले तौर पर संदर्भित करना है। उदाहरण के लिए: किसी के पास क्लास MY_CLASS में `फू' सुविधा हो सकती है और इसे इसके द्वारा संदर्भित किया जा सकता है: | ||
<सिंटैक्सहाइलाइट लैंग= एफिल लाइन हाइलाइट= 10 > | <सिंटैक्सहाइलाइट लैंग= एफिल लाइन हाइलाइट= 10 > | ||
Line 145: | Line 145: | ||
* जब किसी फलन के बाहर, वैश्विक स्थान में उपयोग किया जाता है, <code>this</code> एन्क्लोजिंग ऑब्जेक्ट को संदर्भित करता है, जो इस मामले में एन्क्लोजिंग ब्राउज़र विंडो है <code>window</code> वस्तु। | * जब किसी फलन के बाहर, वैश्विक स्थान में उपयोग किया जाता है, <code>this</code> एन्क्लोजिंग ऑब्जेक्ट को संदर्भित करता है, जो इस मामले में एन्क्लोजिंग ब्राउज़र विंडो है <code>window</code> वस्तु। | ||
* जब ग्लोबल स्पेस में परिभाषित किसी फलन में उपयोग किया जाता है, तब कीवर्ड क्या होता है <code>this</code> संदर्भित करता है यह इस पर निर्भर करता है कि फलन को कैसे कॉल किया जाता है। जब ऐसे फलन को सीधे कॉल किया जाता है (उदा. <code>f(x)</code>), <code>this</code> उस वैश्विक स्थान को संदर्भित करेगा जिसमें फलन परिभाषित किया गया है, और जिसमें अन्य वैश्विक फलन और चर भी उपस्तिथ हो सकते हैं (या सख्त मोड में, यह है <code>undefined</code>). यदि वैश्विक फलन युक्त है <code>this</code> चूँकि, दस्तावेज़ ऑब्जेक्ट में किसी तत्व के ईवेंट हैंडलर के भाग के रूप में कॉल किया जाता है <code>this</code> कॉलिंग HTML तत्व को संदर्भित करेगा। | * जब ग्लोबल स्पेस में परिभाषित किसी फलन में उपयोग किया जाता है, तब कीवर्ड क्या होता है <code>this</code> संदर्भित करता है यह इस पर निर्भर करता है कि फलन को कैसे कॉल किया जाता है। जब ऐसे फलन को सीधे कॉल किया जाता है (उदा. <code>f(x)</code>), <code>this</code> उस वैश्विक स्थान को संदर्भित करेगा जिसमें फलन परिभाषित किया गया है, और जिसमें अन्य वैश्विक फलन और चर भी उपस्तिथ हो सकते हैं (या सख्त मोड में, यह है <code>undefined</code>). यदि वैश्विक फलन युक्त है <code>this</code> चूँकि, दस्तावेज़ ऑब्जेक्ट में किसी तत्व के ईवेंट हैंडलर के भाग के रूप में कॉल किया जाता है <code>this</code> कॉलिंग HTML तत्व को संदर्भित करेगा। | ||
* जब किसी विधि का उपयोग करके कॉल किया जाता है <code>new</code> कीवर्ड (उदा. <code>var c = new Thing()</code>) फिर थिंग के | * जब किसी विधि का उपयोग करके कॉल किया जाता है <code>new</code> कीवर्ड (उदा. <code>var c = new Thing()</code>) फिर थिंग के अंदर <code>this</code> थिंग ऑब्जेक्ट को ही संदर्भित करता है। | ||
* जब किसी फलन को किसी ऑब्जेक्ट की प्रॉपर्टी के रूप में जोड़ा जाता है और उस ऑब्जेक्ट की विधि के रूप में बुलाया जाता है (उदाहरण के लिए) <code>obj.f(x)</code>), <code>this</code> उस ऑब्जेक्ट को संदर्भित करेगा जिसके | * जब किसी फलन को किसी ऑब्जेक्ट की प्रॉपर्टी के रूप में जोड़ा जाता है और उस ऑब्जेक्ट की विधि के रूप में बुलाया जाता है (उदाहरण के लिए) <code>obj.f(x)</code>), <code>this</code> उस ऑब्जेक्ट को संदर्भित करेगा जिसके अंदर फलन निहित है।<ref>Crockford, Douglas, 2008. ''JavaScript: The Good Parts''. O'Reilly Media Inc. and Yahoo! Inc. Chapter 4, ''Functions'', p 28. {{ISBN|978-0-596-51774-8}}</ref><ref>Powell, Thomas A, and Schneider, Fritz, 2012. ''JavaScript: The Complete Reference, Third Edition.'' McGraw-Hill. Chapter 5, ''Functions'', pp 170–1. {{ISBN|978-0-07-174120-0}}</ref> इसे मैन्युअल रूप से निर्दिष्ट करना भी संभव है <code>this</code> किसी फलन को कॉल करते समय, का उपयोग करके <code>.call()</code> या <code>.apply()</code> फलन ऑब्जेक्ट के तरीके।<ref>Goodman, Danny, with Morrison, Michael, 2004. ''JavaScript Bible, 5th Edition.'' Wiley Publishing, Inc., Indianapolis, USA. Chapter 33, ''Functions and Custom Objects'', p 987. {{ISBN|0-7645-5743-2}}</ref> उदाहरण के लिए, विधि कॉल <code>obj.f(x)</code> के रूप में भी लिखा जा सकता है <code>obj.f.call(obj, x)</code>. | ||
के विभिन्न अर्थों के इर्द-गिर्द काम करना <code>this</code> DOM ईवेंट हैंडलर जैसे नेस्टेड फ़ंक्शंस में, इसे सहेजना जावास्क्रिप्ट में सामान्य मुहावरा है <code>this</code> वेरिएबल में कॉलिंग ऑब्जेक्ट का संदर्भ (सामान्यतः कहा जाता है <code>that</code> या <code>self</code>), और फिर नेस्टेड फ़ंक्शंस में कॉलिंग ऑब्जेक्ट को संदर्भित करने के लिए वेरिएबल का उपयोग करें। | के विभिन्न अर्थों के इर्द-गिर्द काम करना <code>this</code> DOM ईवेंट हैंडलर जैसे नेस्टेड फ़ंक्शंस में, इसे सहेजना जावास्क्रिप्ट में सामान्य मुहावरा है <code>this</code> वेरिएबल में कॉलिंग ऑब्जेक्ट का संदर्भ (सामान्यतः कहा जाता है <code>that</code> या <code>self</code>), और फिर नेस्टेड फ़ंक्शंस में कॉलिंग ऑब्जेक्ट को संदर्भित करने के लिए वेरिएबल का उपयोग करें। | ||
Line 240: | Line 240: | ||
=== एक्सबेस++ === | === एक्सबेस++ === | ||
<code>Self</code> किसी वर्ग के तरीकों के | <code>Self</code> किसी वर्ग के तरीकों के अंदर सख्ती से उपयोग किया जाता है। | ||
संदर्भित करने का दूसरा प्रणाली <code>Self</code> उपयोग करना है <code>::</code>. | संदर्भित करने का दूसरा प्रणाली <code>Self</code> उपयोग करना है <code>::</code>. |
Revision as of 15:52, 4 August 2023
यह, स्वयं, और मी आरक्षित शब्द हैं जिनका उपयोग कुछ कंप्यूटर प्रोग्रामिंग भाषाओं में ऑब्जेक्ट, क्लास या अन्य इकाई को संदर्भित करने के लिए किया जाता है जिसका वर्तमान में चल रहें कोड का एक भाग हैं। इन कीवर्ड द्वारा संदर्भित इकाई इस प्रकार निष्पादन संदर्भ पर निर्भर करती है (जैसे कि किस ऑब्जेक्ट की विधि कहलाती है)। भिन्न-भिन्न प्रोग्रामिंग भाषाएं इन कीवर्ड का उपयोग थोड़े भिन्न तरीके से करती हैं। उन भाषाओं में जहां "यह" जैसा कीवर्ड अनिवार्य है, कीवर्ड वर्तमान ऑब्जेक्ट में संग्रहीत डेटा और विधियों तक पहुंचने का एकमात्र प्रणाली है। जहां वैकल्पिक हो, वह ही नाम से वेरिएबल और फ़ंक्शंस को स्पष्ट कर सकते हैं।
वस्तु-उन्मुख प्रोग्रामिंग
अनेक ऑब्जेक्ट ओरिएंटेड प्रोग्रामिंग भाषाओं में, this
(यह भी कहा जाता है self
या Me
) वेरिएबल है जिसका उपयोग इंस्टेंस विधियों में उस ऑब्जेक्ट को संदर्भित करने के लिए किया जाता है जिस पर वह काम कर रहे हैं। पहली OO भाषा, SIMULA 67, ने this
स्थानीय ऑब्जेक्ट को स्पष्ट रूप से संदर्भित करने के लिए इसका उपयोग किया।[1]: 4.3.2.3 C++ और इससे शैली में व्युत्पन्न भाषाएं (जैसे Java, C#, D और पीएचपी) भी सामान्यतः उपयोग की जाती हैं this
. स्मॉलटॉक और अन्य, जैसे ऑब्जेक्ट पास्कल, पर्ल, पायथन (प्रोग्रामिंग भाषा), रूबी (प्रोग्रामिंग भाषा), रस्ट (प्रोग्रामिंग भाषा), उद्देश्य सी , डेटाफ्लेक्स और स्विफ्ट (प्रोग्रामिंग भाषा), उपयोग करें self
. माइक्रोसॉफ्ट के मूल दृश्य Me
का उपयोग करता है।
यह अवधारणा सभी भाषाओं में समान है: this
सामान्यतः अपरिवर्तनीय संदर्भ (कंप्यूटर विज्ञान) या सूचक (कंप्यूटर प्रोग्रामिंग) है जो वर्तमान वस्तु को संदर्भित करता है; वर्तमान ऑब्जेक्ट अधिकांशतः वह कोड होता है जो संपत्ति (प्रोग्रामिंग) , विधि (कंप्यूटर प्रोग्रामिंग), सब-रूटीन या फलन के लिए 'पैरेंट' या 'इनवॉकेंट' के रूप में कार्य करता है जिसमें सम्मिलित होता है this
कीवर्ड. किसी वस्तु के ठीक से निर्माण या त्वरितीकरण के पश्चात्, this
सदैव वैध संदर्भ होता है. कुछ भाषाओं को स्पष्ट रूप से इसकी आवश्यकता होती है; अन्य लोग अपने वर्ग के प्रतीकों को दृश्यमान बनाने के लिए इसका अंतर्निहित रूप से उपयोग करने के लिए शाब्दिक सीमा का उपयोग करते हैं। या वैकल्पिक रूप से, वर्तमान वस्तु द्वारा संदर्भित this
स्वतंत्र कोड ऑब्जेक्ट हो सकता है जिसने कीवर्ड वाले फलन या विधि को कॉल किया हो this
. ऐसी बात होती है, उदाहरण के लिए, जब किसी वेब पेज में एचटीएमएल टैग से जुड़ा जावास्क्रिप्ट ईवेंट हैंडलर कीवर्ड वाले फलन को कॉल करता है this
दस्तावेज़ ऑब्जेक्ट के बाहर वैश्विक स्थान में संग्रहीत; उस संदर्भ में, this
दस्तावेज़ ऑब्जेक्ट के अंदर पृष्ठ तत्व को संदर्भित करेगा, संलग्न विंडो ऑब्जेक्ट को नहीं।[2]
कुछ भाषाओं में, उदाहरण के लिए C++, Java और Raku this
या self
कीवर्ड (कंप्यूटर प्रोग्रामिंग) है, और वेरिएबल स्वचालित रूप से इंस्टेंस विधियों में उपस्तिथ होता है। दूसरों में, उदाहरण के लिए पायथन, रस्ट और पर्ल 5 में, इंस्टेंस विधि का पहला पैरामीटर ऐसा संदर्भ है। इसे स्पष्ट रूप से निर्दिष्ट करने की आवश्यकता है। पायथन और पर्ल में, पैरामीटर को आवश्यक रूप से नाम देने की आवश्यकता नहीं है this
या self
; इसे किसी अन्य पैरामीटर की तरह प्रोग्रामर द्वारा स्वतंत्र रूप से नामित किया जा सकता है। चूँकि, अनौपचारिक परंपरा के अनुसार, पर्ल या पायथन में इंस्टेंस विधि के पहले पैरामीटर को self नाम दिया गया है। जंग के लिए स्वयं वस्तु को बुलाए जाने की आवश्यकता होती है &self
या self
, इस बात पर निर्भर करता है कि क्या इनवोक किया गया फलन इनवोकेंट को उधार लेता है, या उसे क्रमशः अंदर ले जाता है।
C++ या Java में स्टेटिक विधियाँ उदाहरणों से नहीं किंतु कक्षाओं से संबद्ध हैं, और इसलिए उनका उपयोग नहीं किया जा सकता है this
, क्योंकि कोई ऑब्जेक्ट नहीं है। अन्य भाषाओं में, जैसे रूबी, स्मॉलटॉक, ऑब्जेक्टिव-सी, या स्विफ्ट, विधि क्लास ऑब्जेक्ट से जुड़ी होती है जिसे इस प्रकार पारित किया जाता है this
, और उन्हें क्लास विधियाँ कहा जाता है। क्लास विधियों के लिए, पायथन क्लास ऑब्जेक्ट तक पहुँचने के लिए cls
का उपयोग करता है।
सूक्ष्मताएँ और कठिनाइयाँ
जब अनुमान लगाने के लिए लेक्सिकल स्कोपिंग का उपयोग किया जाता है this
, का उपयोग this
कोड में, चूंकि यह अवैध नहीं है, यह रखरखाव प्रोग्रामर के लिए चेतावनी की घंटी बजा सकता है, चूंकि इसके अभी भी वैध उपयोग हैं this
इस मामले में, जैसे कि ही नाम के स्थानीय चर द्वारा छिपे हुए उदाहरण चर का संदर्भ देना, या यदि विधि वर्तमान ऑब्जेक्ट का संदर्भ , अर्थात this
, अपने आप वापस करना चाहती है।
कुछ कंपाइलरों (उदाहरण के लिए जीएनयू कंपाइलर संग्रह) में, सी++ इंस्टेंस विधियों के पॉइंटर्स को स्पष्ट रूप से इस पॉइंटर this
पैरामीटर के साथ सीधे किसी अन्य प्रकार के पॉइंटर पर डाला जा सकता है [3]
खुला प्रत्यावर्तन
इसका प्रेषण शब्दार्थ this
, अर्थात् वह विधि चालू रहती है this
गतिशील रूप से प्रेषित होते हैं, इसे ओपन रिकर्सन के रूप में जाना जाता है, और इसका कारण है कि यह विधियां व्युत्पन्न कक्षाओं या ऑब्जेक्ट्स द्वारा ओवरराइडिंग की जा सकती हैं। इसके विपरीत, किसी फलन का प्रत्यक्ष नामित रिकर्सन या अज्ञात रिकर्सन प्रारंभिक बाइंडिंग के साथ बंद रिकर्सन का उपयोग करता है। उदाहरण के लिए, फैक्टोरियल के लिए निम्नलिखित पर्ल कोड में, टोकन __SUB__
वर्तमान फलन का संदर्भ है:
use feature ":5.16";
sub {
my $x = shift;
$x == 0 ? 1 : $x * __SUB__->( $x - 1 );
}
इसके विपरीत, C++ में (स्पष्ट का उपयोग करके this
स्पष्टता के लिए, चूंकि आवश्यक नहीं) this
ऑब्जेक्ट से ही जुड़ जाता है, किन्तु यदि क्लास विधि को आधार में "वर्चुअल" अर्थात बहुरूपी घोषित किया गया था, तब इसे डायनेमिक डिस्पैच (देर देर से बाइंडिंग) के माध्यम से हल किया जाता है जिससे कि व्युत्पन्न कक्षाएं इसे ओवरराइड कर सकें।
unsigned int factorial(unsigned int n)
{
if (n == 0)
return 1;
else
return n * this->factorial(n - 1);
}
यह उदाहरण कृत्रिम है, क्योंकि यह प्रत्यक्ष प्रत्यावर्तन है, इसलिए ओवरराइडिंग है फैक्टोरियल विधि इस फलन को ओवरराइड करना इस फ़ंक्शन को ओवरराइड कर देगा; अधिक प्राकृतिक उदाहरण तब होते हैं जब व्युत्पन्न वर्ग में विधि बेस क्लास में या पारस्परिक पुनरावृत्ति के स्थितियोंमें उसी विधि को कॉल करती है।[4][5]
अशक्त बेस क्लास समस्या के लिए ओपन रिकर्सन को दोषी ठहराया गया है, जिसमें सुझाव दिया गया है कि प्रणाली को प्रयुक्त किया जाए this
खुले रिकर्सन (गतिशील प्रेषण, देर से बाइंडिंग) के अतिरिक्त बंद रिकर्सन (स्थैतिक प्रेषण, प्रारंभिक बाइंडिंग) के लिए डिफ़ॉल्ट, विशेष रूप से अनुरोध किए जाने पर केवल खुले रिकर्सन का उपयोग करना; बाहरी कॉल (उपयोग नहीं कर रहे हैं this
) सदैव की तरह गतिशील रूप से भेजा जाएगा।[6][7] जिस तरह से इसे जेडीके में व्यवहार में हल किया जाता है वह निश्चित प्रोग्रामर अनुशासन के माध्यम से होता है; इस अनुशासन को सी. रूबी और जी. टी. लीवेन्स द्वारा औपचारिक रूप दिया गया है; इसमें मूल रूप से निम्नलिखित नियम सम्मिलित हैं:[8]
- कोई कोड प्रयुक्त नहीं होता
public
तरीकों परthis
. - कोड जिसे आंतरिक रूप से पुन: उपयोग किया जा सकता है (उसी वर्ग के अन्य तरीकों से आह्वान करके) में समाहित किया गया है
protected
याprivate
प्रणाली; यदि इसे सीधे उपयोगकर्ताओं के सामने प्रदर्शित करने की आवश्यकता है, तब आवरणpublic
विधि आंतरिक विधि को कॉल करती है। - शुद्ध कार्य विधियों के लिए पिछली अनुशंसा में ढील दी जा सकती है।
कार्यान्वयन
सी++
C++ के प्रारंभिक संस्करण इसकी अनुमति देंगे this
सूचक बदला जाए; ऐसा करने से प्रोग्रामर यह बदल सकता है कि कोई विधि किस ऑब्जेक्ट पर काम कर रही है। यह सुविधा अंततः हटा दी गई, और वर्तमान this
C++ में वैल्यू (कंप्यूटर साइंस)#असाइनमेंट है: एल-वैल्यू और आर-वैल्यू|आर-वैल्यू।[9]
C++ के प्रारंभिक संस्करणों में संदर्भ सम्मिलित नहीं थे और यह सुझाव दिया गया है कि यदि शुरुआत से ही C++ में ऐसा होता, this
संदर्भ होता, सूचक नहीं।[10]
C++ वस्तुओं को स्रोत कोड कथन के साथ स्वयं को delete this
नष्ट करने देता है: .
सी
कीवर्ड this
सी शार्प (प्रोग्रामिंग भाषा) में|सी# संदर्भ प्रकारों के लिए जावा की तरह ही काम करता है। चूँकि, C# मान प्रकार के अंदर, this
सामान्य परिवर्तनीय चर संदर्भ के समान होने के कारण, इसमें अधिक भिन्न शब्दार्थ हैं, और यह किसी असाइनमेंट के बाईं ओर भी हो सकता है।
का प्रयोग this
C# में विधि के अंदर बाहरी फ़ील्ड वैरिएबल के संदर्भ की अनुमति देना है जिसमें स्थानीय वैरिएबल होता है जिसका नाम समान होता है। ऐसी स्थिति में, उदाहरण के लिए, कथन var n = localAndFieldname;
विधि के अंदर स्थानीय चर का प्रकार और मान निर्दिष्ट किया जाएगा localAndFieldname
को n
, जबकि कथन var n = this.localAndFieldname;
बाहरी फ़ील्ड वैरिएबल का प्रकार और मान n
निर्दिष्ट करेगा .[11]
डी
डी में (प्रोग्रामिंग भाषा) this
किसी वर्ग, संरचना या संघ विधि में संलग्न समुच्चय के उदाहरण के अपरिवर्तनीय संदर्भ को संदर्भित किया जाता है। कक्षाएं संदर्भ प्रकार के प्रकार हैं, संरचनाएं और यूनियन मूल्य प्रकार हैं। डी के पहले संस्करण में, कीवर्ड this
उस ऑब्जेक्ट के उदाहरण के लिए सूचक के रूप में उपयोग किया जाता है जिससे विधि जुड़ी हुई है, जबकि डी 2 में इसमें संदर्भ द्वारा अंतर्निहित कॉल का चरित्र होता है |ref
फलन तर्क.
डायलन
प्रोग्रामिंग भाषा में डायलन (प्रोग्रामिंग भाषा), जो ऑब्जेक्ट-ओरिएंटेड भाषा है जो बहुपद्धति का समर्थन करती है और इसकी अवधारणा नहीं है this
, किसी ऑब्जेक्ट को संदेश भेजना अभी भी सिंटैक्स में रखा जाता है। नीचे दिए गए दोनों फॉर्म ही तरह से काम करते हैं; अंतर केवल वाक्यात्मक शर्करा है।
ऑब्जेक्ट.विधि(परम1, परम2)
और
विधि (ऑब्जेक्ट, परम1, परम2)
एफिल
एक वर्ग पाठ के अंदर, वर्तमान प्रकार वर्तमान वर्ग से प्राप्त प्रकार है। किसी कक्षा की सुविधाओं (दिनचर्या, आदेश और प्रश्न) के अंदर, कोई कीवर्ड का उपयोग कर सकता है Current
वर्तमान वर्ग और उसकी विशेषताओं का संदर्भ देने के लिए। कीवर्ड का उपयोग Current
कीवर्ड के रूप में वैकल्पिक है Current
इसका तात्पर्य केवल वर्तमान वर्ग सुविधा के नाम को खुले तौर पर संदर्भित करना है। उदाहरण के लिए: किसी के पास क्लास MY_CLASS में `फू' सुविधा हो सकती है और इसे इसके द्वारा संदर्भित किया जा सकता है:
<सिंटैक्सहाइलाइट लैंग= एफिल लाइन हाइलाइट= 10 >
कक्षा मेरी कक्षा सुविधा--पहुँच foo: पूर्णांक मेरा_फलन: पूर्णांक करना परिणाम:= फू अंत अंत
</सिंटैक्सहाइलाइट>[12]
पंक्ति #10 (ऊपर) का निहित संदर्भ है Current
सरल `फू' पर कॉल करके।
पंक्ति #10 (नीचे) का स्पष्ट संदर्भ है Current
`Current.foo' पर कॉल द्वारा।
<सिंटैक्सहाइलाइट लैंग= एफिल लाइन हाइलाइट= 10 >
कक्षा मेरी कक्षा सुविधा--पहुँच foo: पूर्णांक मेरा_फलन: पूर्णांक करना परिणाम:=वर्तमान.फू अंत अंत
</सिंटैक्सहाइलाइट>
कोई भी दृष्टिकोण संकलक को स्वीकार्य है, किन्तु निहित संस्करण (उदा. x:= foo
) को प्राथमिकता दी जाती है क्योंकि यह कम क्रियात्मक है।
अन्य भाषाओं की तरह, ऐसे समय भी आते हैं जब कीवर्ड का उपयोग किया जाता है Current
अनिवार्य है, जैसे:
<सिंटैक्सहाइलाइट लैंग= एफिल लाइन हाइलाइट= 11 >
कक्षा मेरी कक्षा सुविधा--पहुँच my_command -- 'वर्तमान' के साथ MY_OTHER_CLASS बनाएं स्थानीय एक्स: मेरी_अन्य_क्लास करना x.make_with_something बनाएं (वर्तमान) अंत अंत
</सिंटैक्सहाइलाइट>
उपरोक्त कोड के मामले में, लाइन #11 पर make_with_something पर कॉल स्पष्ट रूप से कीवर्ड को पास करके वर्तमान क्लास को पास कर रही है Current
.
जावा
कीवर्ड this
जावा (प्रोग्रामिंग भाषा) भाषा कीवर्ड है जो उस वर्ग के वर्तमान उदाहरण का प्रतिनिधित्व करता है जिसमें यह दिखाई देता है। इसका उपयोग क्लास वेरिएबल्स और विधियों तक पहुंचने के लिए किया जाता है।
चूँकि जावा में सभी इंस्टेंस विधियाँ आभासी हैं, this
कभी भी शून्य नहीं हो सकता.[13]
जावास्क्रिप्ट
जावास्क्रिप्ट में, जो प्रोग्रामिंग या स्क्रिप्टिंग भाषा है जिसका उपयोग वेब ब्राउज़र में बड़े पैमाने पर किया जाता है, this
महत्वपूर्ण कीवर्ड है, चूँकि इसका मूल्यांकन किस प्रकार किया जाता है यह इस बात पर निर्भर करता है कि इसका उपयोग कहाँ किया जाता है।
- जब किसी फलन के बाहर, वैश्विक स्थान में उपयोग किया जाता है,
this
एन्क्लोजिंग ऑब्जेक्ट को संदर्भित करता है, जो इस मामले में एन्क्लोजिंग ब्राउज़र विंडो हैwindow
वस्तु। - जब ग्लोबल स्पेस में परिभाषित किसी फलन में उपयोग किया जाता है, तब कीवर्ड क्या होता है
this
संदर्भित करता है यह इस पर निर्भर करता है कि फलन को कैसे कॉल किया जाता है। जब ऐसे फलन को सीधे कॉल किया जाता है (उदा.f(x)
),this
उस वैश्विक स्थान को संदर्भित करेगा जिसमें फलन परिभाषित किया गया है, और जिसमें अन्य वैश्विक फलन और चर भी उपस्तिथ हो सकते हैं (या सख्त मोड में, यह हैundefined
). यदि वैश्विक फलन युक्त हैthis
चूँकि, दस्तावेज़ ऑब्जेक्ट में किसी तत्व के ईवेंट हैंडलर के भाग के रूप में कॉल किया जाता हैthis
कॉलिंग HTML तत्व को संदर्भित करेगा। - जब किसी विधि का उपयोग करके कॉल किया जाता है
new
कीवर्ड (उदा.var c = new Thing()
) फिर थिंग के अंदरthis
थिंग ऑब्जेक्ट को ही संदर्भित करता है। - जब किसी फलन को किसी ऑब्जेक्ट की प्रॉपर्टी के रूप में जोड़ा जाता है और उस ऑब्जेक्ट की विधि के रूप में बुलाया जाता है (उदाहरण के लिए)
obj.f(x)
),this
उस ऑब्जेक्ट को संदर्भित करेगा जिसके अंदर फलन निहित है।[14][15] इसे मैन्युअल रूप से निर्दिष्ट करना भी संभव हैthis
किसी फलन को कॉल करते समय, का उपयोग करके.call()
या.apply()
फलन ऑब्जेक्ट के तरीके।[16] उदाहरण के लिए, विधि कॉलobj.f(x)
के रूप में भी लिखा जा सकता हैobj.f.call(obj, x)
.
के विभिन्न अर्थों के इर्द-गिर्द काम करना this
DOM ईवेंट हैंडलर जैसे नेस्टेड फ़ंक्शंस में, इसे सहेजना जावास्क्रिप्ट में सामान्य मुहावरा है this
वेरिएबल में कॉलिंग ऑब्जेक्ट का संदर्भ (सामान्यतः कहा जाता है that
या self
), और फिर नेस्टेड फ़ंक्शंस में कॉलिंग ऑब्जेक्ट को संदर्भित करने के लिए वेरिएबल का उपयोग करें।
उदाहरण के लिए:
// In this example $ is a reference to the jQuery library
$(".element").hover(function() {
// Here, both this and that point to the element under the mouse cursor.
var that = this;
$(this).find('.elements').each(function() {
// Here, this points to the DOM element being iterated.
// However, that still points to the element under the mouse cursor.
$(this).addClass("highlight");
});
});
विशेष रूप से, जावास्क्रिप्ट दोनों का उपयोग करता है this
और संबंधित कीवर्ड self
[17] (अधिकांश अन्य भाषाओं के विपरीत जो या दूसरे को नियोजित करती हैं), साथ self
विशेष रूप से वेब कर्मियों तक ही सीमित रखा जा रहा है।[18]
अंत में, वैश्विक (विंडो या समतुल्य) ऑब्जेक्ट को विशेष रूप से संदर्भित करने के विश्वसनीय तरीके के रूप में, जावास्क्रिप्ट की सुविधा है globalThis
कीवर्ड.[19]
दो
लुआ में, self
जब फ़ंक्शंस का उपयोग करके परिभाषित किया जाता है तब सिंटैक्टिक शुगर के रूप में बनाया जाता है :
ऑपरेटर।[20] किसी विधि का उपयोग करते समय :
, अनुक्रमित की जा रही वस्तु को अंतर्निहित रूप से प्रयुक्त किए जा रहे फलन के पहले तर्क के रूप में दिया जाएगा।
उदाहरण के लिए, निम्नलिखित दो कार्य समतुल्य हैं:
local obj = {}
function obj.foo(arg1, arg2)
print(arg1, arg2) -- cannot use "self" here
end
function obj:bar(arg)
print(self, arg) -- "self" is an implicit first argument before arg
end
-- All functions can be invoked both ways, with "." or with ":"
obj:foo("Foo") -- equivalent to obj.foo(obj, "Foo")
obj.bar(obj, "Bar") -- equivalent to obj:bar("Bar")
लुआ स्वयं ऑब्जेक्ट-ओरिएंटेड नहीं है, किन्तु जब इसे मेटाटेबल्स नामक अन्य सुविधा के साथ जोड़ा जाता है, तब इसका उपयोग किया जाता है self
प्रोग्रामर को फलन को ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग के समान तरीके से परिभाषित करने देता है।
पावरशेल
PowerShell में विशेष स्वचालित चर $_
पाइपलाइन ऑब्जेक्ट में वर्तमान ऑब्जेक्ट सम्मिलित है। आप इस वेरिएबल का उपयोग उन कमांड्स में कर सकते हैं जो प्रत्येक ऑब्जेक्ट पर या पाइपलाइन में चयनित ऑब्जेक्ट पर कार्रवाई करते हैं।[21]
<सिंटैक्सहाइलाइट लैंग=पीएस1 >
एक , दो , तीन | % { $_ लिखें }
</सिंटैक्सहाइलाइट>पॉवरशेल 5.0 से भी प्रारंभ होता है, जो कक्षाओं और अन्य उपयोगकर्ता-परिभाषित प्रकारों को परिभाषित करने के लिए औपचारिक वाक्यविन्यास जोड़ता है,[22] $this
वेरिएबल ऑब्जेक्ट के वर्तमान उदाहरण का वर्णन करता है।
पायथन
पायथन में, के लिए कोई कीवर्ड नहीं है this
. जब किसी सदस्य फलन को किसी ऑब्जेक्ट पर कॉल किया जाता है, तब यह ऑब्जेक्ट के क्लास ऑब्जेक्ट पर उसी नाम के साथ सदस्य फलन को आमंत्रित करता है, ऑब्जेक्ट स्वचालित रूप से फलन के पहले तर्क से जुड़ा होता है। इस प्रकार, विधि (कंप्यूटर प्रोग्रामिंग) का अनिवार्य पहला पैरामीटर के रूप में कार्य करता है this
; इस पैरामीटर को पारंपरिक रूप से नाम दिया गया है self
, किन्तु नाम कुछ भी रखा जा सकता है।
कक्षा विधियों में (के साथ बनाया गया classmethod
डेकोरेटर), पहला तर्क क्लास ऑब्जेक्ट को ही संदर्भित करता है, और इसे पारंपरिक रूप से कहा जाता है cls
; इनका उपयोग मुख्य रूप से इनहेरिटेबल कंस्ट्रक्टर्स के लिए किया जाता है,[23] जहां पैरामीटर के रूप में क्लास का उपयोग कंस्ट्रक्टर को उपवर्गीकृत करने की अनुमति देता है। स्थैतिक तरीकों में (के साथ बनाया गया staticmethod
डेकोरेटर), कोई विशेष पहला तर्क उपस्तिथ नहीं है।
जंग
रस्ट में, प्रकारों को उनसे जुड़े कार्यों से भिन्न घोषित किया जाता है। पारंपरिक रूप से ऑब्जेक्ट-ओरिएंटेड भाषाओं में इंस्टेंस विधियों के अनुरूप डिज़ाइन किए गए फ़ंक्शंस को स्पष्ट रूप से लिया जाना चाहिए self
उनके पहले पैरामीटर के रूप में। फिर इन फ़ंक्शंस का उपयोग करके कॉल किया जा सकता है instance.method()
सिंटैक्स चीनी. उदाहरण के लिए:
struct Foo {
bar: i32,
}
impl Foo {
fn new() -> Foo {
Foo { bar: 0, }
}
fn refer(&self) {
println!("{}", self.bar);
}
fn mutate(&mut self, baz: i32) {
self.bar = baz;
}
fn consume(self) {
self.refer();
}
}
यह प्रकार को परिभाषित करता है, Foo
, जिसके चार संबद्ध कार्य हैं। पहला, Foo::new()
, इंस्टेंस फलन नहीं है और इसे प्रकार उपसर्ग के साथ निर्दिष्ट किया जाना चाहिए। शेष तीन सभी लेते हैं self
विभिन्न तरीकों से पैरामीटर, और इसे a पर कॉल किया जा सकता है Foo
उदाहरण के लिए डॉट-नोटेशन सिंटैक्स शुगर का उपयोग किया जाता है, जो स्पष्ट रूप से टाइप-योग्य फलन नाम को कॉल करने के सामान्तर है self
पहला पैरामीटर.
let mut foo = Foo::new(); // must called as a type-specified function
foo.refer(); // prints "0". Foo::refer() has read-only access to the foo instance
foo.mutate(5); // mutates foo in place, permitted by the &mut specification, need foo to be declared mut
foo.consume(); // prints "5" and destroys foo, as Foo::consume() takes full ownership of self
// equivalent to foo.refer()
Foo::refer(foo); // compilation error: foo is out of scope
स्वयं
Self (प्रोग्रामिंग भाषा) भाषा का नाम self के इसी प्रयोग के आधार पर रखा गया है।
एक्सबेस++
Self
किसी वर्ग के तरीकों के अंदर सख्ती से उपयोग किया जाता है।
संदर्भित करने का दूसरा प्रणाली Self
उपयोग करना है ::
.
यह भी देखें
- अनाम पुनरावर्तन – Recursion without calling a function by name
- वंशानुक्रम (वस्तु-उन्मुख प्रोग्रामिंग)
- आत्म संदर्भ
- सिज़ोफ्रेनिया (वस्तु-उन्मुख प्रोग्रामिंग)
- प्रोग्राम खंड उपसर्ग
संदर्भ
- ↑ Dahl, Ole-Johan; Myhrhaug, Bjørn; Nygaard, Kristen (1970). "Common Base Language, Norwegian Computing Center".
- ↑ Powell, Thomas A, and Schneider, Fritz, 2012. JavaScript: The Complete Reference, Third Edition. McGraw-Hill. Chapter 11, Event Handling, p 428. ISBN 978-0-07-174120-0
- ↑ Using the GNU Compiler Collection (GCC) – Bound member functions
- ↑ "Closed and Open Recursion", Ralf Hinze, July 2007
- ↑ Open Recursion, Lambda the Ultimate
- ↑ "Selective Open Recursion: A Solution to the Fragile Base Class Problem", Jonathan Aldrich
- ↑ "Selective Open Recursion: A Solution to the Fragile Base Class Problem", Lambda the Ultimate
- ↑ Aldrich, Jonathan, and Kevin Donnelly. "Selective open recursion: Modular reasoning about components and inheritance." SAVCBS 2004 Specification and Verification of Component-Based Systems (2004): 26. citing for the JDK-adopted solution C. Ruby and G. T. Leavens. "Safely Creating Correct Subclasses without Seeing Superclass Code". In Object-Oriented Programming Systems, Languages, and Applications, October 2000. doi:10.1145/353171.353186 also available as technical report TR #00-05d
- ↑ ISO/IEC 14882:2003(E): Programming Languages - C++. ISO/IEC. 2003.
- ↑ Stroustrup: C++ Style and Technique FAQ
- ↑ De Smet, Bart, 2011. C# 4.0 Unleashed. Sams Publishing, Indianapolis, USA. Chapter 4, Language Essentials, p 210. ISBN 978-0-672-33079-7
- ↑ NOTE: The line numbers are for reference purposes only. Eiffel does not have line numbers in the class text. However, there is a line number option in the Eiffel Studio IDE, which can be optionally turned on for reference purposes (e.g. pair programming, etc).
- ↑ Barnes, D. and Kölling, M. Objects First with Java. "...the reason for using this construct [this] is that we have a situation that is known as name overloading - the same name being used for two different entities... It is important to understand that the fields and the parameters are separate variables that exist independently of each other, even though they share similar names. A parameter and a field sharing a name is not really a problem in Java."[citation needed]
- ↑ Crockford, Douglas, 2008. JavaScript: The Good Parts. O'Reilly Media Inc. and Yahoo! Inc. Chapter 4, Functions, p 28. ISBN 978-0-596-51774-8
- ↑ Powell, Thomas A, and Schneider, Fritz, 2012. JavaScript: The Complete Reference, Third Edition. McGraw-Hill. Chapter 5, Functions, pp 170–1. ISBN 978-0-07-174120-0
- ↑ Goodman, Danny, with Morrison, Michael, 2004. JavaScript Bible, 5th Edition. Wiley Publishing, Inc., Indianapolis, USA. Chapter 33, Functions and Custom Objects, p 987. ISBN 0-7645-5743-2
- ↑ Mozilla Developer Network: Window.self
- ↑ Mozilla Developer Network: Web Worker API
- ↑ Mozilla Developer Network: globalThis
- ↑ "Programming in Lua : 16".
- ↑ msdn. "PowerShell: About Automatic Variables". docs.microsoft.com (in English). Retrieved 2018-03-22.
- ↑ msdn. "about_Classes". docs.microsoft.com (in English). Retrieved 2018-12-17.
- ↑ Unifying types and classes in Python 2.2, Guido van Rossum, "Overriding the __new__ method"
अग्रिम पठन
- मेयर्स, स्कॉट, 1995। अधिक प्रभावी सी++: आपके प्रोग्राम और डिज़ाइन को उत्तम बनाने के 35 नए तरीके। ISBN 0-201-63371-X स्कॉट मेयर्स
- स्ट्रॉस्ट्रुप, बर्जने, 1994। सी++ का डिज़ाइन और विकास। एडिसन-वेस्ले पब। कं ISBN 0-201-54330-3 बज़्ने स्ट्रॉस्ट्रुप