डक टाइपिंग
Type systems |
---|
General concepts |
Major categories |
|
Minor categories |
कंप्यूटर प्रोग्रामिंग में डक टाइपिंग बतख परीक्षण का एक अनुप्रयोग है- यदि यह डक की तरह चलता है और यह बत्तख की तरह कांपता है, तो यह डक होना चाहिए- यह निर्धारित करने के लिए कि किसी वस्तु (कंप्यूटर विज्ञान) का उपयोग किसी विशेष उद्देश्य के लिए किया जा सकता है या नहीं। कर्ताकारक टंकण के साथ, एक वस्तु किसी दिए गए प्रकार की होती है, यदि इसे घोषित किया जाता है (या यदि वस्तु के साथ किसी प्रकार का संबंध वस्तु वंशानुक्रम जैसे तंत्र के माध्यम से अनुमान लगाया जाता है)। डक टाइपिंग में, एक वस्तु दिए गए प्रकार की होती है, यदि उसमें उस प्रकार के लिए आवश्यक सभी विधि (कंप्यूटर प्रोग्रामिंग) और गुण हों।[1][2] डक टाइपिंग को किसी दी गई वस्तु और किसी प्रकार की आवश्यकताओं के बीच उपयोग-आधारित संरचनात्मक तुल्यता के रूप में देखा जा सकता है। संरचनात्मक प्रकार तुल्यता की और अधिक व्याख्या के लिए संरचनात्मक टाइपिंग देखें।
उदाहरण
यह पायथन (प्रोग्रामिंग लैंग्वेज) 3 में एक सरल उदाहरण है जो दर्शाता है कि किसी भी संदर्भ में किसी भी वस्तु का उपयोग कैसे किया जा सकता है, जब तक कि इसका उपयोग इस तरह से नहीं किया जाता है कि यह समर्थन नहीं करता है।
<वाक्यविन्यास लैंग = पायथन लाइन = 1> वर्ग बतख:
डीईएफ़ तैरना (स्वयं): प्रिंट (डक स्विमिंग)
डेफ फ्लाई (स्वयं): प्रिंट (डक फ्लाइंग)
कक्षा व्हेल:
डीईएफ़ तैरना (स्वयं): प्रिंट (व्हेल तैराकी)
[डक (), व्हेल ()] में जानवरों के लिए:
पशु तैरना () पशु मक्खी ()
</वाक्यविन्यास हाइलाइट>
आउटपुट:
सिंटैक्सहाइलाइट लैंग = आउटपुट> बतख तैरना बत्तख उड़ रही है व्हेल तैरना विशेषता त्रुटि: 'व्हेल' ऑब्जेक्ट में कोई विशेषता नहीं है 'फ्लाई' </वाक्यविन्यास हाइलाइट> इसलिए, अगर हम यह मान लें कि जो कुछ भी तैर सकता है वह बतख है क्योंकि बतख तैर सकती हैं, तो हम व्हेल को बतख मानेंगे, लेकिन, अगर हम यह भी मान लें कि उसे उड़ने में सक्षम होना चाहिए, तो व्हेल को नहीं माना जाएगा एक बतख।
सांख्यिकीय रूप से टाइप की गई भाषाओं में
कुछ टाइप सिस्टम में # स्टेटिक टाइपिंग लैंग्वेज जैसे बू (प्रोग्रामिंग भाषा) [3] और D_(प्रोग्रामिंग_भाषा),[4][5] क्लास टाइप चेकिंग को संकलन समय के बजाय रन टाइम पर होने के लिए निर्दिष्ट किया जा सकता है।
अन्य प्रकार की प्रणालियों के साथ तुलना
संरचनात्मक प्रकार प्रणाली ्स
डक टाइपिंग समान है, लेकिन स्ट्रक्चरल टाइप सिस्टम से अलग है। स्ट्रक्चरल टाइपिंग एक टाइप सिस्टम#स्टेटिक टाइपिंग सिस्टम है जो एक प्रकार की संरचना द्वारा टाइप संगतता और समानता निर्धारित करता है, जबकि डक टाइपिंग टाइप सिस्टम#डायनेमिक टाइपिंग है और टाइप की संरचना के केवल उस भाग द्वारा टाइप संगतता निर्धारित करता है जिसे रन टाइम (प्रोग्राम) के दौरान एक्सेस किया जाता है जीवनचक्र चरण)।
टाइपप्रति ,[6] एल्म (प्रोग्रामिंग भाषा),[7] और पायथन (प्रोग्रामिंग भाषा)[8] भाषाएँ अलग-अलग डिग्री के लिए संरचनात्मक टाइपिंग का समर्थन करती हैं।
प्रोटोकॉल और इंटरफेस
प्रोटोकॉल (ऑब्जेक्ट-ओरिएंटेड प्रोग्रामिंग) स्पष्ट रूप से घोषित करने का एक तरीका प्रदान करता है, कि कुछ विधियों, ऑपरेटरों या व्यवहारों को परिभाषित करने की आवश्यकता है (उदाहरण के लिए एक क्वैक () विधि होनी चाहिए)। यदि कोई तृतीय-पक्ष पुस्तकालय एक वर्ग को लागू करता है जिसे संशोधित नहीं किया जा सकता है, तो क्लाइंट उस पुस्तकालय के लिए अज्ञात इंटरफ़ेस के साथ इसका उदाहरण उपयोग नहीं कर सकता है, भले ही कक्षा वास्तव में इंटरफ़ेस आवश्यकताओं को पूरा करती हो। इस समस्या का एक सामान्य समाधान एडेप्टर पैटर्न है। इसके विपरीत, बतख टाइपिंग के तहत, एडॉप्टर की आवश्यकता के बिना वस्तु को सीधे स्वीकार किया जाएगा।
साँचे या सामान्य प्रकार
टेम्पलेट मेटाप्रोग्रामिंग, या सामान्य प्रोग्रामिंग फ़ंक्शंस या विधियाँ टाइप सिस्टम # स्टेटिक टाइपिंग संदर्भ में डक टेस्ट लागू करती हैं; यह टाइप सिस्टम के सभी फायदे और नुकसान लाता है # सामान्य रूप से व्यवहार में स्थैतिक और गतिशील प्रकार की जाँच। डक टाइपिंग भी अधिक लचीली हो सकती है, जिसमें केवल वास्तव में रनटाइम पर बुलाए जाने वाले तरीकों को लागू करने की आवश्यकता होती है, जबकि टेम्प्लेट को उन सभी तरीकों के कार्यान्वयन की आवश्यकता होती है जो संकलन समय पर अगम्य कोड साबित नहीं हो सकते।
जावा, स्काला और ऑब्जेक्टिव-सी जैसी भाषाओं में, प्रतिबिंब (कंप्यूटर प्रोग्रामिंग) का उपयोग यह जांचने के लिए किया जा सकता है कि क्या ऑब्जेक्ट विधियों को लागू करते हैं या रनटाइम पर आवश्यक तरीके भी जोड़ते हैं।
उदाहरण के लिए, जावा (प्रोग्रामिंग भाषा) का MethodHandle API कर सकता है इस तरह इस्तेमाल किया जाए।[9]
यह भी देखें
संदर्भ
- ↑ "Glossary — Python 3.7.1 documentation". docs.python.org. Retrieved 2018-11-08.
- ↑ "पायथन डक टाइपिंग - उदाहरण". Techie Hours (in English). 2020-06-28. Retrieved 2020-07-26.
- ↑ Boo: Duck TypingArchived October 6, 2008, at the Wayback Machine
- ↑ "Dynamic classes and duck typing".
- ↑ "Metaprogramming - duck typing in D".
- ↑ "SE Radio Episode 384: Boris Cherny on TypeScript". se-radio.net. Retrieved 2019-10-25.
- ↑ Czaplicki, Evan. "Core Language · An Introduction to Elm". Retrieved 30 January 2017.
- ↑ "PEP 544 – Protocols: Structural subtyping (static duck typing)".
- ↑ "StackOverflow: Implement duck typing using java MethodHandles". Retrieved 13 June 2020.