वैरिएडिक फ़ंक्शन: Difference between revisions
No edit summary |
m (Sugatha moved page विविध प्रकार्य to वैरिएडिक फ़ंक्शन) |
||
| (8 intermediate revisions by 5 users not shown) | |||
| Line 1: | Line 1: | ||
गणित और [[कंप्यूटर प्रोग्रामिंग]] में, एक '''वैरिएडिक फ़ंक्शन''' अनिश्चितकालीन कार्य होता है, अर्थात, जो तर्कों की एक परिवर्तनीय संख्या को स्वीकार करता है। वैरिएडिक फ़ंक्शन के लिए समर्थन विभिन्न [[प्रोग्रामिंग भाषा|प्रोग्रामिंग]] लैंग्वेज में व्यापक रूप से भिन्न होता है। | |||
गणित और [[कंप्यूटर प्रोग्रामिंग]] में, एक | |||
''परिवर्तनशील'' शब्द एक नवविज्ञानवाद है, जो 1936-1937 तक चला।<ref>Henry S. Leonard and H. N. Goodman, ''A calculus of individuals''. Abstract of a talk given at the Second Meeting of the Association for Symbolic Logic, held in Cambridge MA on December 28–30, 1936, [https://www.jstor.org/stable/2268861], ''Journal of Symbolic Logic'' '''2'''(1) 1937, 63.</ref> 1970 के दशक तक इस शब्द का व्यापक रूप से उपयोग नहीं किया गया था। | ''परिवर्तनशील'' शब्द एक नवविज्ञानवाद है, जो 1936-1937 तक चला।<ref>Henry S. Leonard and H. N. Goodman, ''A calculus of individuals''. Abstract of a talk given at the Second Meeting of the Association for Symbolic Logic, held in Cambridge MA on December 28–30, 1936, [https://www.jstor.org/stable/2268861], ''Journal of Symbolic Logic'' '''2'''(1) 1937, 63.</ref> 1970 के दशक तक इस शब्द का व्यापक रूप से उपयोग नहीं किया गया था। | ||
==अवलोकन== | ==अवलोकन== | ||
ऐसे कई गणितीय और तार्किक संचालन हैं जो स्वाभाविक रूप से | ऐसे कई गणितीय और तार्किक संचालन हैं जो स्वाभाविक रूप से वैरिएडिक फ़ंक्शन के रूप में सामने आते हैं। उदाहरण के लिए, संख्याओं का योग या तार या अन्य अनुक्रमों का संयोजन ऐसे संचालन हैं जिन्हें किसी भी संख्या में संकार्य पर लागू माना जा सकता है (भले ही इन मामलों में औपचारिक रूप से सहयोगी संपत्ति लागू होती है)। | ||
एक अन्य संचालन जिसे कई | एक अन्य संचालन जिसे कई लैंग्वेज में वैरिएडिक फ़ंक्शन के रूप में कार्यान्वित किया गया है वह है आउटपुट संरूपण। [[सी (प्रोग्रामिंग भाषा)|सी (प्रोग्रामिंग लैंग्वेज)]] कार्य मुद्रण और समान लिस्प कार्य प्रारूप ऐसे दो उदाहरण हैं। दोनों एक तर्क लेते हैं जो आउटपुट के स्वरूपण को निर्दिष्ट करता है, और किसी भी संख्या में तर्क जो स्वरूपित किए जाने वाले मान प्रदान करते हैं। | ||
वैरिएडिक फ़ंक्शन कुछ लैंग्वेज में प्रकार-सुरक्षा समस्याओं को उजागर कर सकते हैं। उदाहरण के लिए, सी का{{code|मुद्रण}}, यदि सावधानी से उपयोग किया जाता है, तो सुरक्षा छिद्रों के एक वर्ग को जन्म दे सकता है जिसे प्रारूप तार हमलों के रूप में जाना जाता है। हमला संभव है क्योंकि वैरिएडिक फ़ंक्शन के लिए लैंग्वेज समर्थन प्रकार-सुरक्षित नहीं है: यह कार्य को ढेर से अधिक तर्कों को लोकप्रिय करने का प्रयास करने की अनुमति देता है, जिससे ढेर दूषित हो जाता है और अप्रत्याशित व्यवहार होता है। इसके परिणामस्वरूप, [[सीईआरटी समन्वय केंद्र]] सी में वैरिएडिक फ़ंक्शन को उच्च-गंभीर सुरक्षा जोखिम मानता है।<ref>{{cite book|last=Klemens|first=Ben|title=21st Century C: C Tips from the New School|publisher=O'Reilly Media, Inc.|date=2014|pages=224|isbn=978-1491904442}}</ref> | |||
कार्यात्मक | कार्यात्मक लैंग्वेज में परिवर्तनशील को [[आवेदन करना]] कार्य का पूरक माना जा सकता है, जो एक कार्य और एक सूची/अनुक्रम/सरणी को तर्क के रूप में लेता है, और उस सूची में दिए गए तर्कों के साथ कार्य को कॉल करता है, इस प्रकार कार्य में तर्कों की एक चर संख्या पारित करता है। कार्यात्मक लैंग्वेज [[हास्केल (प्रोग्रामिंग भाषा)|हास्केल (प्रोग्रामिंग लैंग्वेज)]] में, प्रकार वर्ग {{code|T}} का मान लौटाकर वैरिएडिक फ़ंक्शन को कार्यान्वित किया जा सकता है ; यदि के उदाहरण {{code|T}} अंतिम वापसी मान हैं {{code|r}} और एक कार्य {{code|1=(T t) => x -> t}}, यह किसी भी संख्या में अतिरिक्त तर्क की अनुमति देता है {{code|x}}. | ||
[[शब्द पुनर्लेखन]] शोध में संबंधित विषय को बचाव या बचाव चर कहा जाता है।<ref>[https://arxiv.org/abs/1503.00336 CLP (H): Constraint Logic Programming for Hedges]</ref> | [[शब्द पुनर्लेखन]] शोध में संबंधित विषय को बचाव या बचाव चर कहा जाता है।<ref>[https://arxiv.org/abs/1503.00336 CLP (H): Constraint Logic Programming for Hedges]</ref> वैरिएडिक के विपरीत, जो तर्कों के साथ कार्य हैं, बचाव स्वयं तर्कों के अनुक्रम हैं। उनके पास उस बिंदु तक बाधाएं भी हो सकती हैं (उदाहरण के लिए, 4 से अधिक तर्क न लें') जहां वे परिवर्तनीय-लंबाई नहीं हैं (जैसे कि 'बिल्कुल 4 तर्क लें') - इस प्रकार उन्हें वैरिएडिक कहना भ्रामक हो सकता है। हालाँकि, वे एक ही घटना का उल्लेख कर रहे हैं, और कभी-कभी वाक्यांशों को मिश्रित किया जाता है, जिसके परिणामस्वरूप वैरिएडिक चर (बचाव का पर्याय) जैसे नाम सामने आते हैं। कार्यात्मक प्रोग्रामिंग और [[शब्द पुनर्लेखन|शब्द]] पुनर्लेखन में चर शब्द के दोहरे अर्थ और तर्कों और चर के बीच अंतर पर ध्यान दें। उदाहरण के लिए, एक शब्द (कार्य) में तीन चर हो सकते हैं, उनमें से एक बचाव है, इस प्रकार शब्द को तीन या अधिक तर्क लेने की अनुमति मिलती है (या यदि बचाव को खाली होने की अनुमति दी जाती है तो दो या अधिक)। | ||
==उदाहरण== | ==उदाहरण== | ||
===सी में=== | ===सी में=== | ||
C (प्रोग्रामिंग | C (प्रोग्रामिंग लैंग्वेज) में वैरिएडिक फ़ंक्शन को सुवाह्य रूप से लागू करने के लिए, मानक stdarg.h|{{code|stdarg.h}} हेडर पंक्ति का उपयोग किया जाता है. पुराने varargs.h|{{code|varargs.h}} हेडर के पक्ष में अस्वीकृत कर दिया गया है {{code|stdarg.h}}. C++ में, हेडर पंक्ति {{code|cstdarg}} प्रयोग किया जाता है।<ref>{{cite web|url=http://www.cplusplus.com/reference/clibrary/cstdarg/|title=<cstdarg> (stdarg.h) - C++ Reference|website=www.cplusplus.com}}</ref> | ||
<syntaxhighlight lang=" | <syntaxhighlight lang="c"> | ||
#include <stdarg.h> | #include <stdarg.h> | ||
#include <stdio.h> | #include<stdio.h> | ||
double average(int count, ...) { | double average(int count, ...) { | ||
| Line 30: | Line 28: | ||
double sum = 0; | double sum = 0; | ||
va_start(ap, count); /* Before C23: Requires the last fixed parameter (to get the address) */ | va_start(ap, count); /* Before C23: Requires the last fixed parameter (to get the address)*/ | ||
for (j = 0; j < count; j++) { | for (j = 0; j < count; j++) { | ||
sum += va_arg(ap, int); /* Increments ap to the next argument. */ | sum += va_arg(ap, int); /* Increments ap to the next argument. */ | ||
| Line 44: | Line 42: | ||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
यह तर्कों की मनमानी संख्या के औसत की गणना करेगा। ध्यान दें कि कार्यों तर्कों की संख्या या उनके प्रकारों को नहीं जानता है। उपरोक्त कार्य अपेक्षा करता है कि प्रकार {{code|int}} होंगे , और तर्कों की संख्या पहले तर्क में पारित की जाएगी (यह एक लगातार उपयोग है लेकिन | यह तर्कों की मनमानी संख्या के औसत की गणना करेगा। ध्यान दें कि कार्यों तर्कों की संख्या या उनके प्रकारों को नहीं जानता है। उपरोक्त कार्य अपेक्षा करता है कि प्रकार {{code|int}} होंगे , और तर्कों की संख्या पहले तर्क में पारित की जाएगी (यह एक लगातार उपयोग है लेकिन लैंग्वेज या संकलनकर्ता द्वारा किसी भी तरह से लागू नहीं किया गया है)। कुछ अन्य मामलों में, उदाहरण के लिए [[ printf | मुद्रण]] , एक प्रारूप तार से तर्कों की संख्या और प्रकार का पता लगाया जाता है। दोनों ही मामलों में, यह प्रोग्रामर पर निर्भर करता है कि वह सही जानकारी प्रदान करे। (वैकल्पिक रूप से, संख्या इंगित करने के लिए {{code|NULL}} जैसे प्रहरी मान का उपयोग किया जा सकता है।) यदि कार्य की अपेक्षा से कम तर्क पारित किए जाते हैं, या तर्क के प्रकार गलत हैं, तो यह इसे मेमोरी के अमान्य क्षेत्रों में पढ़ने का कारण बन सकता है और प्रारूप तार हमले जैसी कमजोरियों को जन्म दे सकता है। . | ||
{{code|stdarg.h}} एक प्रकार घोषित करता है, {{code|va_list}}, और चार मैक्रोज़ को परिभाषित करता है:{{code|va_start}}, {{code|va_arg}},{{code|va_copy}}, और{{code|va_end}}. प्रत्येक मंगलाचरण {{code|va_start}} और {{code|va_copy}} के अनुरूप मंगलाचरण से मेल खाना चाहिए {{code|va_end}}. परिवर्तनीय तर्कों के साथ काम करते समय, एक कार्य सामान्यता एक प्रकार का चर घोषित करता है {{code|va_list}} ({{code|ap}} उदाहरण में) जिसे वृहत् द्वारा कुशलतापूर्वक किया जाएगा। | {{code|stdarg.h}} एक प्रकार घोषित करता है, {{code|va_list}}, और चार मैक्रोज़ को परिभाषित करता है:{{code|va_start}}, {{code|va_arg}},{{code|va_copy}}, और{{code|va_end}}. प्रत्येक मंगलाचरण {{code|va_start}} और {{code|va_copy}} के अनुरूप मंगलाचरण से मेल खाना चाहिए {{code|va_end}}. परिवर्तनीय तर्कों के साथ काम करते समय, एक कार्य सामान्यता एक प्रकार का चर घोषित करता है {{code|va_list}} ({{code|ap}} उदाहरण में) जिसे वृहत् द्वारा कुशलतापूर्वक किया जाएगा। | ||
# {{code|va_start}} दो तर्क लेता है, a {{code|va_list}} ऑब्जेक्ट और कार्य के अंतिम प्राचल का संदर्भ (अध्याहार से पहले वाला; बहुत बड़ा इसका उपयोग अपने चाल प्राप्त करने के लिए करता है)। C23 में, दूसरे तर्क की अब आवश्यकता नहीं होगी और | # {{code|va_start}} दो तर्क लेता है, a {{code|va_list}} ऑब्जेक्ट और कार्य के अंतिम प्राचल का संदर्भ (अध्याहार से पहले वाला; बहुत बड़ा इसका उपयोग अपने चाल प्राप्त करने के लिए करता है)। C23 में, दूसरे तर्क की अब आवश्यकता नहीं होगी और वैरिएडिक फ़ंक्शन को दीर्घवृत्त से पहले नामित प्राचल की आवश्यकता नहीं होगी।<ref name=N2975>{{cite web|url=https://open-std.org/JTC1/SC22/WG14/www/docs/n2975.pdf|title=WG14-N2975 : Relax requirements for variadic parameter lists, v3|date=2022-04-15|last1=Gilding|first1=Alex|last2=Meneide|first2=JeanHeyd}}</ref> यह आरंभ करता है {{code|va_list}} द्वारा उपयोग के लिए वस्तु {{code|va_arg}} या {{code|va_copy}}. यदि संदर्भ गलत है तो संकलनकर्ता सामान्यता एक चेतावनी जारी करेगा (उदाहरण के लिए पिछले प्राचल से भिन्न प्राचल का संदर्भ, या पूरी तरह से अलग ऑब्जेक्ट का संदर्भ), लेकिन संकलन को सामान्य रूप से पूरा होने से नहीं रोकेगा। | ||
# {{code|va_arg}} दो तर्क लेता है, | # {{code|va_arg}} दो तर्क लेता है, एक {{code|va_list}} ऑब्जेक्ट (पहले प्रारंभ किया गया) और एक प्रकार का वर्णनकर्ता। यह अगले चर तर्क तक विस्तारित होता है, और इसमें निर्दिष्ट प्रकार होता है। का क्रमिक आह्वान {{code|va_arg}} प्रत्येक परिवर्तनीय तर्क को बारी-बारी से संसाधित करने की अनुमति दें। अनिर्दिष्ट व्यवहार तब होता है जब प्रकार गलत है या कोई अगला चर तर्क नहीं है। | ||
# {{code|va_end}} एक तर्क लेता है, | # {{code|va_end}} एक तर्क लेता है, एक {{code|va_list}} वस्तु। यह साफ़ करने का काम करता है. उदाहरण के लिए, यदि कोई चर तर्कों को एक से अधिक बार अवलोकन करना चाहता है, तो प्रोग्रामर आपका पुनः आरंभ करेगा {{code|va_list}} आह्वान द्वारा वस्तु {{code|va_end}} और तब {{code|va_start}} फिर से उस पर. | ||
# {{code|va_copy}} दो तर्क लेता है, दोनों {{code|va_list}} वस्तुएं। यह दूसरे को (जिसे प्रारंभ किया गया होगा) पहले में | # {{code|va_copy}} दो तर्क लेता है, दोनों {{code|va_list}} वस्तुएं। यह दूसरे को (जिसे प्रारंभ किया गया होगा) पहले में प्रतिरूप करता है। एक से अधिक उदाहरणों में परिवर्तनीय तर्कों को अवलोकन करने पर वापस जाकर, इसे लागू करके प्राप्त किया जा सकता है {{code|va_start}} पहले पर {{code|va_list}}, फिर उपयोग करना {{code|va_copy}} इसे एक सेकंड में प्रतिरूप करने के लिए {{code|va_list}}. परिवर्तनीय तर्कों को पहली बार अवलोकन करने के बाद {{code|va_arg}} और पहला {{code|va_list}} (इसके साथ इसका निपटान {{code|va_end}}), प्रोग्रामर चर तर्कों को दूसरी बार अवलोकन कर सकता है {{code|va_arg}} और दूसरा {{code|va_list}}. {{code|va_end}} को प्रतिरूप पर भी कॉल करने की आवश्यकता है {{code|va_list}} युक्त कार्य के वापस आने से पहले। | ||
'''C# में''' | |||
सी पार्श्व संकेतशब्द का उपयोग करके वैरिएडिक फ़ंक्शन का वर्णन करता है।, तर्कों के लिए एक प्रकार प्रदान किया जाना चाहिए हालांकि {{code|object[]}} का उपयोग अर्थबोधक के रूप में उपयोग किया जा सकता है। आजीविका स्थान पर, आप या तो तर्कों को एक-एक करके सूचीबद्ध कर सकते हैं, या आवश्यक तत्व प्रकार वाले पहले से मौजूद सरणी को सौंप सकते हैं। वैरिएडिक रूप का उपयोग बाद के लिए [[वाक्यात्मक शर्करा]] है। | |||
प्रणाली का उपयोग करना; | |||
कक्षा कार्यक्रम | कक्षा कार्यक्रम | ||
{ | { | ||
static int Foo(int a, int b, params int[] args) | |||
{ | { | ||
// a | // Return the sum of the integers in args, ignoring a and b. int sum = 0; | ||
foreach (int i in args) | foreach (int i in args) | ||
sum + = मैं; | |||
return sum; | |||
} | } | ||
static void Main(string[] args) | |||
{ | { | ||
Console.WriteLine(Foo(1,2)); // 0 | |||
Console.WriteLine(Foo(1, 2, 3, 10, 20)); //33 | |||
int[] | int[] manyValues = new int[] {13, 14, 15 }; | ||
Console.WriteLine(Foo(1,2, manyValues)); //42 | |||
} | } | ||
} | } | ||
=== | ===C++ में=== | ||
C++ में बुनियादी विविधतापूर्ण सुविधा | C++ में बुनियादी विविधतापूर्ण सुविधा बहुत हद तक C के समान है। एकमात्र अंतर वाक्य रचना में है, जहां दीर्घवृत्त से पहले अल्पविराम को छोड़ा जा सकता है। C++ नामित मापदंडों के बिना वैरिएडिक फ़ंक्शन की अनुमति देता है लेकिन तब से उन तर्कों तक पहुंचने का कोई तरीका प्रदान नहीं करता है <code>va_start</code> कार्य के अंतिम निश्चित तर्क के नाम की आवश्यकता है। <!-- When C23 is released the text should be updated to reflect that this is a difference between the languages. When C++26 ports the one argument va_start to C++ (https://wg21.link/p2537) this should be updated again. See also the C section of the article. --> | ||
# | #include <iostream> | ||
# | #include <cstdarg> | ||
void simple_printf(const char* fmt...) // C-style const char* fmt, ... is also valid | |||
{ | { | ||
va_list | va_list args; | ||
va_start(args, fmt); | va_start(args, fmt); | ||
while (*fmt != '\0') { | |||
if (*fmt == 'd') { | |||
int i = va_arg(args, int); | int i = va_arg(args, int); | ||
std::cout << i << '\n'; | std::cout << i << '\n'; | ||
} | } else if (*fmt == 'c') { | ||
// | // note automatic conversion to integral type | ||
int c = va_arg(args, int); | int c = va_arg(args, int); | ||
std::cout << static_cast<char>(c) << '\n'; | std::cout << static_cast<char>(c) << '\n'; | ||
} | } else if (*fmt == 'f') { | ||
double d = va_arg(args, double); | |||
std::cout << d << '\n'; | std::cout << d << '\n'; | ||
} | } | ||
++ | ++ fmt; | ||
} | } | ||
| Line 109: | Line 109: | ||
} | } | ||
int main() | |||
{ | { | ||
simple_printf(dcff, 3, 'a', 1.999, 42.5); | |||
} | } | ||
[[विविध टेम्पलेट्स]] (पैरामीटर पैक) का उपयोग C++ में अंतर्निहित | [[विविध टेम्पलेट्स|वैरिएडिक नमूना]] (पैरामीटर पैक) का उपयोग C++ में अंतर्निहित लैंग्वेज (उच्च-क्रम कार्य) के साथ भी किया जा सकता है। | ||
#include <iostream> | |||
< | template <typename... Ts> | ||
void foo_print(Ts... args) | |||
{ | { | ||
((std::cout << args << ''), ...); | ((std::cout << args << ''), ...); | ||
} | } | ||
int main() | |||
{ | { | ||
std::cout << std::boolalpha; | std::cout << std::boolalpha; | ||
foo_print(1, 3.14f); // 1 3.14 | foo_print(1, 3.14f); // 1 3.14 | ||
foo_print(Foo, 'b', true, nullptr); // | foo_print(Foo, 'b', true, nullptr); // Foo b true nullptr | ||
} | } | ||
सी++ के लिए [[सीईआरटी कोडिंग मानक]] दुरुपयोग के कम जोखिम के कारण सी-स्टाइल | सी++ के लिए [[सीईआरटी कोडिंग मानक]] दुरुपयोग के कम जोखिम के कारण सी-स्टाइल वैरिएडिक फ़ंक्शन की तुलना में सी++ में वैरिएडिक [[विविध टेम्पलेट्स|नमूना]] (पैरामीटर पैक) के उपयोग को दृढ़ता से प्राथमिकता देते हैं।<ref>{{cite web |title=DCL50-CPP. Do not define a C-style variadic function |url=https://wiki.sei.cmu.edu/confluence/display/cplusplus/DCL50-CPP}}</ref> | ||
===गो में=== | ===गो में=== | ||
गो (प्रोग्रामिंग | गो (प्रोग्रामिंग लैंग्वेज) में वैरिएडिक फ़ंक्शन को किसी भी संख्या में अनुगामी तर्कों के साथ बुलाया जा सकता है।<ref>{{Cite web|url=https://gobyexample.com/variadic-functions|title=Go by Example: Variadic Functions}}</ref> {{code|fmt.Println}} एक सामान्य वैरिएडिक फ़ंक्शन है; यह कैच-ऑल प्रकार के रूप में एक खाली अंतराफलक का उपयोग करता है। | ||
<syntaxhighlight lang="go"> | <syntaxhighlight lang="go"> | ||
| Line 148: | Line 149: | ||
func sum(nums ...int) { | func sum(nums ...int) { | ||
fmt.Print("The sum of ", nums) // Also a variadic function. | fmt.Print("The sum of ", nums) // Also a variadic function. | ||
. | |||
sum := 0 | |||
for _, num := range nums { | for _, num := range nums { | ||
total += num | total += num | ||
| Line 157: | Line 159: | ||
func main() { | func main() { | ||
// Variadic functions can be called in the usual way with individual | // Variadic functions can be called in the usual way with individual | ||
// arguments. | |||
sum(1, 2) // "The sum of [1 2] is 3" | sum(1, 2) // "The sum of [1 2] is 3" | ||
sum(1, 2, 3) // "The sum of [1 2 3] is 6" | sum(1, 2, 3) // "The sum of [1 2 3] is 6" | ||
| Line 170: | Line 172: | ||
आउटपुट: | आउटपुट: | ||
कुल मिलाकर [1 2] का योग 3 है | |||
[1 2] का योग 3 है | |||
[1 2 3] का योग 6 है | कुल मिलाकर [1 2 3] का योग 6 है | ||
[1 2 3 4] का योग 10 है | |||
कुल मिलाकर [1 2 3 4] का योग 10 है | |||
===जावा में=== | ===जावा में=== | ||
C# की तरह, | C# की तरह, [[जावा (प्रोग्रामिंग भाषा)|जावा (प्रोग्रामिंग लैंग्वेज)]] में } प्रकार कैच-ऑल के रूप में उपलब्ध है। | ||
<syntaxhighlight lang="java"> | <syntaxhighlight lang="java"> | ||
public class Program { | public class Program { | ||
| Line 209: | Line 211: | ||
console.log(sum()); // 0 | console.log(sum()); // 0 | ||
</syntaxhighlight> | </syntaxhighlight> | ||
तर्क ऑब्जेक्ट का उपयोग करके एक | तर्क ऑब्जेक्ट का उपयोग करके एक वैरिएडिक फ़ंक्शन बनाना भी संभव है, हालांकि यह केवल प्रकार्य संकेतशब्द के साथ बनाए गए प्रकार्य के साथ प्रयोग करने योग्य है। | ||
<syntaxhighlight lang="javascript"> | <syntaxhighlight lang="javascript"> | ||
| Line 222: | Line 224: | ||
=== [[लुआ (प्रोग्रामिंग भाषा)]] में === | === [[लुआ (प्रोग्रामिंग भाषा)|लुआ (प्रोग्रामिंग लैंग्वेज)]] में === | ||
लुआ (प्रोग्रामिंग | लुआ (प्रोग्रामिंग लैंग्वेज) प्रकार्य वापसी संकेतशब्द का उपयोग करके अन्य मानों की तरह ही अन्य प्रकार्य में वेरार्ग पास कर सकते हैं। लूआ संस्करण 5.2 या उच्चतर का उपयोग करके तालिकाओं को वैरिएडिक फ़ंक्शन में पारित किया जा सकता है<ref>{{Cite web |title=Lua 5.2 Reference Manual |url=https://www.lua.org/manual/5.2/manual.html#pdf-table.unpack |access-date=2023-02-05 |website=www.lua.org}}</ref> {{Code|table.unpack}}, या लुआ 5.1 या उससे कम<ref>{{Cite web |title=Lua 5.1 Reference Manual |url=https://www.lua.org/manual/5.1/manual.html#pdf-unpack |access-date=2023-02-05 |website=www.lua.org}}</ref> {{Code|unpack}}. वेरार्ग को एक मान के रूप में वेरार्ग के साथ एक तालिका बनाकर उपयोग किया जा सकता है।<syntaxhighlight lang="lua"> | ||
function sum(...) --... designates varargs | function sum(...) --... designates varargs | ||
local sum=0 | local sum=0 | ||
for _,v in pairs({...}) do --creating a table with a varargs is the same as creating one with standard values | for _,v in pairs({...}) do --creating a table with a varargs is the same as creating one with standard values | ||
| Line 246: | Line 249: | ||
end | end | ||
return table.unpack(processed) --returns all entries in a way that can be used as a vararg | return table.unpack(processed) --returns all entries in a way that can be used as a vararg | ||
end | end | ||
| Line 252: | Line 256: | ||
===[[पास्कल (प्रोग्रामिंग भाषा)]] में=== | ===[[पास्कल (प्रोग्रामिंग भाषा)|पास्कल (प्रोग्रामिंग लैंग्वेज)]] में=== | ||
पास्कल (प्रोग्रामिंग लैंग्वेज) में चार अंतर्निहित प्रक्रियाएं हैं जिन्हें वैरिएडिक के रूप में परिभाषित किया गया है, जो इस विशेष स्थिति के कारण, संकलक के लिए आंतरिक हैं। ये हैं पढ़ें, {{code|readln}}, लिखें, और {{code|writeln}} प्रक्रियाएं. हालाँकि, प्रक्रियाओं या कार्यों के लिए डिफ़ॉल्ट तर्क की अनुमति देने वाले वैकल्पिक विनिर्देश हैं जो उन्हें वैरिएडिक रूप से काम करते हैं, साथ ही [[बहुरूपता (कंप्यूटर विज्ञान)|बहुरूपता (कंप्यूटर विज्ञान)भी है]] जो एक प्रक्रिया या प्रकार्य को अलग-अलग पैरामीटर रखने की अनुमति देता है। वह {{code|read[ln]}} और {{code|write[ln]}} सभी प्रक्रियाओं का प्रारूप समान है: | |||
पास्कल (प्रोग्रामिंग | |||
पढ़ें[एलएन] [( [फ़ाइल ,] चर [, चर ...] )] ; | |||
लिखें[एलएन] [( [फ़ाइल][, मूल्य [, मूल्य ...] )] ; | लिखें[एलएन] [( [फ़ाइल][, मूल्य [, मूल्य ...] )] ; | ||
कहाँ | कहाँ | ||
* {{code|file}} एक वैकल्पिक फ़ाइल | * {{code|file}} एक वैकल्पिक फ़ाइल चर है, जिसे यदि छोड़ दिया जाए तो यह डिफ़ॉल्ट हो जाता है {{code|input}} के लिए {{code|read}} और {{code|readln}}, या डिफ़ॉल्ट {{code|output}} के लिए {{code|write}} और {{code|writeln}}; | ||
* {{code|variable}} एक अदिश राशि है जैसे कि चार (वर्ण), पूर्णांक, या वास्तविक (या कुछ | * {{code|variable}} एक अदिश राशि है जैसे कि चार (वर्ण), पूर्णांक, या वास्तविक (या कुछ संकलक के लिए, कुछ रिकॉर्ड प्रकार या सरणी प्रकार जैसे स्ट्रिंग); और | ||
* {{code|value}} एक चर या स्थिरांक है। | * {{code|value}} एक चर या स्थिरांक है। | ||
उदाहरण: | उदाहरण: | ||
<syntaxhighlight lang="pascal" line> | <syntaxhighlight lang="pascal" line="1"> | ||
var | var | ||
f: text; | f: text; | ||
ch: char | ch: ;char | ||
n,a,I,B: Integer; | n,a,I,B: Integer; | ||
S: String; | S: String; | ||
| Line 300: | Line 303: | ||
end. | end. | ||
</syntaxhighlight> | </syntaxhighlight> | ||
उपरोक्त उदाहरण में, जहां तक | उपरोक्त उदाहरण में, जहां तक संकलक का सवाल है, लाइनें 9 और 13 समान हैं, क्योंकि यदि {{code|input}} फ़ाइल चर को {{code|read}} या {{code|readln}} कथन द्वारा पढ़ा जा रहा है तो फ़ाइल चर को छोड़ा जा सकता है। साथ ही, संकलक पंक्ति 15 और 20 को समान मानता है, क्योंकि यदि फ़ाइल चर को {{code|output}}में लिखा जा रहा है ,तो इसे छोड़ा जा सकता है, जिसका अर्थ है (पंक्ति 20 पर) क्योंकि प्रक्रिया में कोई तर्क पारित नहीं किया जा रहा है, कोष्ठक तर्कों को सूचीबद्ध करते हैं मिटाया जा सकता है। पंक्ति 26 से पता चलता है कि {{code|writeln}} कथन में किसी भी संख्या में तर्क हो सकते हैं, और वे एक उद्धृत स्ट्रिंग, एक चर, या यहां तक कि एक सूत्र परिणाम भी हो सकते हैं। | ||
ऑब्जेक्ट पास्कल बहुरूपी प्रक्रियाओं और कार्यों का समर्थन करता है, जहां विभिन्न प्रक्रियाओं या कार्यों का एक ही नाम हो सकता है लेकिन उन्हें दिए गए तर्कों से अलग किया जा सकता है। | ऑब्जेक्ट पास्कल बहुरूपी प्रक्रियाओं और कार्यों का समर्थन करता है, जहां विभिन्न प्रक्रियाओं या कार्यों का एक ही नाम हो सकता है लेकिन उन्हें दिए गए तर्कों से अलग किया जा सकता है। | ||
पास्कल | पास्कल अनुपस्थिति तर्कों का भी समर्थन करता है, जहां तर्क का मान, यदि प्रदान नहीं किया गया है, तो एक अनुपस्थिति मान दिया जाता है। | ||
पहले उदाहरण के लिए, बहुरूपता, निम्नलिखित पर विचार करें: | पहले उदाहरण के लिए, बहुरूपता, निम्नलिखित पर विचार करें: | ||
| Line 314: | Line 317: | ||
function add(r1:real,a2:integer):real; begin add := a1+real(a2) end; | function add(r1:real,a2:integer):real; begin add := a1+real(a2) end; | ||
</syntaxhighlight> | </syntaxhighlight> | ||
उपरोक्त उदाहरण में, यदि {{code|add}} | उपरोक्त उदाहरण में, यदि दो पूर्णांक मानों के साथ को{{code|add}} कहा जाता है, पंक्ति 1 पर घोषित प्रकार्य को बुलाया जाएगा; यदि तर्कों में से एक पूर्णांक है और एक वास्तविक है, तो पंक्ति 3 या 4 पर प्रकार्य को कॉल किया जाता है, जो इस पर निर्भर करता है कि कौन सा पूर्णांक है। यदि दोनों वास्तविक हैं, तो पंक्ति 2 पर प्रकार्य को कॉल किया जाता है। | ||
अनुपस्थिति पैरामीटर के लिए, निम्नलिखित पर विचार करें: | |||
<syntaxhighlight lang="pascal" line> | <syntaxhighlight lang="pascal" line> | ||
| Line 343: | Line 346: | ||
end. | end. | ||
</syntaxhighlight> | </syntaxhighlight> | ||
पंक्ति 6 पर, (और नीचे की पंक्तियाँ) पैरामीटर {{code|1== 0}} | पंक्ति 6 पर, (और नीचे की पंक्तियाँ में) पैरामीटर {{code|1== 0}} संकलक को बताता है, "यदि कोई तर्क प्रदान नहीं किया गया है, तो तर्क को शून्य मानें"। पंक्ति 19 पर, कोई तर्क नहीं दिया गया, इसलिए प्रकार्य {{code|0}} लौटाता है। लाइन 20 पर, किसी भी तर्क के लिए या तो एक संख्या या एक चर प्रदान किया जा सकता है, और जैसा कि लाइन 22 पर दिखाया गया है, एक स्थिरांक। | ||
===[[पीएचपी]] में=== | ===[[पीएचपी]] में=== | ||
| Line 356: | Line 359: | ||
echo sum(1, 2, 3); // 6 | echo sum(1, 2, 3); // 6 | ||
</syntaxhighlight> | </syntaxhighlight> | ||
और | और वैरिएडिक तर्क टाइप किए: | ||
<syntaxhighlight lang="php"> | <syntaxhighlight lang="php"> | ||
| Line 369: | Line 372: | ||
===पायथन में=== | ===पायथन में=== | ||
[[पायथन (प्रोग्रामिंग भाषा)]] विभिन्न प्रकार के तर्कों की परवाह नहीं करता है। | [[पायथन (प्रोग्रामिंग भाषा)|पायथन (प्रोग्रामिंग लैंग्वेज)]] विभिन्न प्रकार के तर्कों की परवाह नहीं करता है। | ||
<syntaxhighlight lang="python"> | <syntaxhighlight lang="python"> | ||
| Line 382: | Line 385: | ||
===रकु में=== | ===रकु में=== | ||
[[राकू (प्रोग्रामिंग भाषा)]] में, विभिन्न प्रकार के | [[राकू (प्रोग्रामिंग भाषा)|राकू (प्रोग्रामिंग लैंग्वेज)]] में, विभिन्न प्रकार के प्रकार्य बनाने वाले पैरामीटर के प्रकार को स्लर्पी एरे पैरामीटर के रूप में जाना जाता है और उन्हें तीन समूहों में वर्गीकृत किया जाता है: | ||
====चपटा घोल==== | ====चपटा घोल==== | ||
इन मापदंडों को एक एकल तारांकन (*) के साथ घोषित किया जाता है और वे तत्वों की एक या अधिक परतों को भंग करके तर्कों को समतल करते हैं जिन्हें पुनरावृत्त किया जा सकता है (यानी, Iterables))। | |||
sub foo($a, $b, *@args) { | |||
say @args.perl; | |||
} | } | ||
foo(1,2) # [] | |||
foo(1,2,3) # [3] | |||
foo(1, 2, 3, "hello" ) # [3 "hello" ] | |||
foo(1, 2, 3, [4, 5], [6]); # [3, 4, 5, 6] | |||
====बिना चपटा घोल==== | ====बिना चपटा घोल==== | ||
ये पैरामीटर दो तारांकन () के साथ घोषित किए गए हैं और वे सूची के | ये पैरामीटर दो तारांकन () के साथ घोषित किए गए हैं और वे सूची के अंदर किसी भी पुनरावृत्त तर्क को समतल नहीं करते हैं, लेकिन तर्क को कमोबेश वैसे ही रखते हैं: | ||
sub bar($a, $b, **@args) { | |||
say @args.perl; | |||
} | } | ||
bar(1,2); # [] | |||
bar(1, 2, 3); #[3] | |||
bar(1, 2, 3, "hello" ); # [3 "hello" ] | |||
bar(1, 2, 3, [4, 5], [6]); # [3, [4, 5], [6]] | |||
< | ====प्रासंगिक घिनौना==== | ||
इन मापदंडों को प्लस (+) चिह्न के साथ घोषित किया जाता है और वे "एकल तर्क नियम लागू करते हैं जो यह तय करता है कि संदर्भ के आधार पर गंदे तर्क को कैसे संभालना है। सीधे शब्दों में कहें, यदि केवल एक ही तर्क पारित किया जाता है और वह तर्क पुनरावृत्त होता है, तो वह तर्क है स्लरी पैरामीटर सरणी को भरने के लिए उपयोग किया जाता है। किसी अन्य मामले में, <code>+@</code> जैसे काम करता है <code>**@</code> (अर्थात, बिना चपटा घोल)। | |||
@args.perl | |||
sub zaz($a, $b, +@args) { | |||
say @args.perl; | |||
} | } | ||
zaz(1, 2); # [] | |||
zaz(1, 2, 3); #[3] | |||
zaz(1, 2, 3, "hello"); # [3 "hello" ] | |||
zaz(1, 2, [4, 5]); # [4, 5], single argument fills up array | |||
zaz(1, 2, 3, [4, 5]); # [3, [4, 5, **behaving as **@ | |||
zaz(1, 2, 3, [4, 5], [6]); # [3, [4, 5], [6, **behaving as **@ | |||
===रूबी में=== | ===रूबी में=== | ||
[[रूबी (प्रोग्रामिंग भाषा)]] विभिन्न प्रकार के तर्कों की परवाह नहीं करती है। | [[रूबी (प्रोग्रामिंग भाषा)|रूबी (प्रोग्रामिंग लैंग्वेज)]] विभिन्न प्रकार के तर्कों की परवाह नहीं करती है। | ||
<syntaxhighlight lang="ruby"> | <syntaxhighlight lang="ruby"> | ||
| Line 445: | Line 456: | ||
=== जंग में === | === जंग में === | ||
ज़ंग (प्रोग्रामिंग लैंग्वेज) प्रकार्य में वैरिएडिक तर्कों का समर्थन नहीं करता है। इसके अतिरिक्त, यह [[मैक्रो (कंप्यूटर विज्ञान)]] का उपयोग करता है।<ref>{{cite web |title=विविधता|url=https://doc.rust-lang.org/rust-by-example/macros/variadics.html |website=Rust By Example}}</ref> | |||
<syntaxhighlight lang="rust"> | <syntaxhighlight lang="rust"> | ||
| Line 472: | Line 483: | ||
} | } | ||
</syntaxhighlight> | </syntaxhighlight> | ||
जंग | जंग एक {{code|c_variadic}} फीचर स्विच के माध्यम से C के वैरिएडिक प्रणाली के साथ बातचीत करने में सक्षम है। अन्य C इंटरफेस की तरह, सिस्टम को जंग के लिए {{code|unsafe}} माना जाता है।<ref>{{cite web |title=2137-variadic |url=https://rust-lang.github.io/rfcs/2137-variadic.html |website=The Rust RFC Book}}</ref> | ||
| Line 494: | Line 505: | ||
===स्विफ्ट में=== | ===स्विफ्ट में=== | ||
[[स्विफ्ट (प्रोग्रामिंग भाषा)]] विभिन्न प्रकार के तर्कों की परवाह करती है, लेकिन सभी को पकड़ती है {{code|Any}} प्रकार उपलब्ध है. | [[स्विफ्ट (प्रोग्रामिंग भाषा)|स्विफ्ट (प्रोग्रामिंग लैंग्वेज)]] विभिन्न प्रकार के तर्कों की परवाह करती है, लेकिन सभी को पकड़ती है {{code|Any}} प्रकार उपलब्ध है. | ||
<syntaxhighlight lang="swift"> | <syntaxhighlight lang="swift"> | ||
| Line 519: | Line 530: | ||
===[[ टी.सी.एल ]] में=== | ===[[ टी.सी.एल ]] में=== | ||
एक टीसीएल प्रक्रिया या लैम्ब्डा तब | एक टीसीएल प्रक्रिया या लैम्ब्डा तब वैरिएडिक होती है जब इसका अंतिम तर्क {{code|args}}होता है : इसमें शेष सभी तर्कों की एक सूची (संभवतः खाली) होगी। यह पैटर्न कई अन्य प्रक्रिया-जैसी विधियों में आम है।<ref>{{cite web |title=प्रोक मैनुअल पेज|url=https://www.tcl.tk/man/tcl/TclCmd/proc.html |website=Tcl/Tk Documentation}}</ref><ref>{{cite web |title=तर्क|url=https://wiki.tcl-lang.org/page/तर्क|website=Tcler's Wiki}}</ref> | ||
<syntaxhighlight lang="tcl"> | <syntaxhighlight lang="tcl"> | ||
| Line 543: | Line 554: | ||
==यह भी देखें== | ==यह भी देखें== | ||
*जावा सिंटैक्स#Varargs | *जावा सिंटैक्स#Varargs | ||
*[[विविध स्थूल]] (सी प्रोग्रामिंग | *[[विविध स्थूल|वैरिएडिक स्थूल]] (सी प्रोग्रामिंग लैंग्वेज) | ||
*[[विविध टेम्पलेट]] | *[[विविध टेम्पलेट|वैरिएडिक टेम्पलेट]] | ||
== टिप्पणियाँ == | == टिप्पणियाँ == | ||
| Line 558: | Line 569: | ||
* [https://web.archive.org/web/20070927215504/http://www.codeproject.com/cpp/argfunctions.asp?df=100&forumid=15556&exp=0&select=503481 Variable Argument Functions] — A tutorial on Variable Argument Functions for C++ | * [https://web.archive.org/web/20070927215504/http://www.codeproject.com/cpp/argfunctions.asp?df=100&forumid=15556&exp=0&select=503481 Variable Argument Functions] — A tutorial on Variable Argument Functions for C++ | ||
* [https://www.gnu.org/software/hello/manual/libc/Variadic-Functions.html GNU libc manual] | * [https://www.gnu.org/software/hello/manual/libc/Variadic-Functions.html GNU libc manual] | ||
[[Category: | [[Category:All articles with unsourced statements]] | ||
[[Category:All pages needing cleanup]] | |||
[[Category:Articles needing cleanup from April 2021]] | |||
[[Category:Articles with hatnote templates targeting a nonexistent page]] | |||
[[Category:Articles with invalid date parameter in template]] | |||
[[Category:Articles with unsourced statements from February 2018]] | |||
[[Category:Cleanup tagged articles with a reason field from April 2021]] | |||
[[Category:Created On 23/06/2023]] | [[Category:Created On 23/06/2023]] | ||
[[Category:Machine Translated Page]] | |||
[[Category:Missing redirects]] | |||
[[Category:Pages with script errors]] | |||
[[Category:Templates Vigyan Ready]] | |||
[[Category:Wikipedia articles needing clarification from May 2018]] | |||
[[Category:Wikipedia pages needing cleanup from April 2021]] | |||
[[Category:उदाहरण के लिए पायथन (प्रोग्रामिंग भाषा) कोड वाले लेख]] | |||
[[Category:सबरूटीन्स]] | |||
Latest revision as of 16:15, 18 October 2023
गणित और कंप्यूटर प्रोग्रामिंग में, एक वैरिएडिक फ़ंक्शन अनिश्चितकालीन कार्य होता है, अर्थात, जो तर्कों की एक परिवर्तनीय संख्या को स्वीकार करता है। वैरिएडिक फ़ंक्शन के लिए समर्थन विभिन्न प्रोग्रामिंग लैंग्वेज में व्यापक रूप से भिन्न होता है।
परिवर्तनशील शब्द एक नवविज्ञानवाद है, जो 1936-1937 तक चला।[1] 1970 के दशक तक इस शब्द का व्यापक रूप से उपयोग नहीं किया गया था।
अवलोकन
ऐसे कई गणितीय और तार्किक संचालन हैं जो स्वाभाविक रूप से वैरिएडिक फ़ंक्शन के रूप में सामने आते हैं। उदाहरण के लिए, संख्याओं का योग या तार या अन्य अनुक्रमों का संयोजन ऐसे संचालन हैं जिन्हें किसी भी संख्या में संकार्य पर लागू माना जा सकता है (भले ही इन मामलों में औपचारिक रूप से सहयोगी संपत्ति लागू होती है)।
एक अन्य संचालन जिसे कई लैंग्वेज में वैरिएडिक फ़ंक्शन के रूप में कार्यान्वित किया गया है वह है आउटपुट संरूपण। सी (प्रोग्रामिंग लैंग्वेज) कार्य मुद्रण और समान लिस्प कार्य प्रारूप ऐसे दो उदाहरण हैं। दोनों एक तर्क लेते हैं जो आउटपुट के स्वरूपण को निर्दिष्ट करता है, और किसी भी संख्या में तर्क जो स्वरूपित किए जाने वाले मान प्रदान करते हैं।
वैरिएडिक फ़ंक्शन कुछ लैंग्वेज में प्रकार-सुरक्षा समस्याओं को उजागर कर सकते हैं। उदाहरण के लिए, सी कामुद्रण, यदि सावधानी से उपयोग किया जाता है, तो सुरक्षा छिद्रों के एक वर्ग को जन्म दे सकता है जिसे प्रारूप तार हमलों के रूप में जाना जाता है। हमला संभव है क्योंकि वैरिएडिक फ़ंक्शन के लिए लैंग्वेज समर्थन प्रकार-सुरक्षित नहीं है: यह कार्य को ढेर से अधिक तर्कों को लोकप्रिय करने का प्रयास करने की अनुमति देता है, जिससे ढेर दूषित हो जाता है और अप्रत्याशित व्यवहार होता है। इसके परिणामस्वरूप, सीईआरटी समन्वय केंद्र सी में वैरिएडिक फ़ंक्शन को उच्च-गंभीर सुरक्षा जोखिम मानता है।[2]
कार्यात्मक लैंग्वेज में परिवर्तनशील को आवेदन करना कार्य का पूरक माना जा सकता है, जो एक कार्य और एक सूची/अनुक्रम/सरणी को तर्क के रूप में लेता है, और उस सूची में दिए गए तर्कों के साथ कार्य को कॉल करता है, इस प्रकार कार्य में तर्कों की एक चर संख्या पारित करता है। कार्यात्मक लैंग्वेज हास्केल (प्रोग्रामिंग लैंग्वेज) में, प्रकार वर्ग T का मान लौटाकर वैरिएडिक फ़ंक्शन को कार्यान्वित किया जा सकता है ; यदि के उदाहरण T अंतिम वापसी मान हैं r और एक कार्य (T t) => x -> t, यह किसी भी संख्या में अतिरिक्त तर्क की अनुमति देता है x.
शब्द पुनर्लेखन शोध में संबंधित विषय को बचाव या बचाव चर कहा जाता है।[3] वैरिएडिक के विपरीत, जो तर्कों के साथ कार्य हैं, बचाव स्वयं तर्कों के अनुक्रम हैं। उनके पास उस बिंदु तक बाधाएं भी हो सकती हैं (उदाहरण के लिए, 4 से अधिक तर्क न लें') जहां वे परिवर्तनीय-लंबाई नहीं हैं (जैसे कि 'बिल्कुल 4 तर्क लें') - इस प्रकार उन्हें वैरिएडिक कहना भ्रामक हो सकता है। हालाँकि, वे एक ही घटना का उल्लेख कर रहे हैं, और कभी-कभी वाक्यांशों को मिश्रित किया जाता है, जिसके परिणामस्वरूप वैरिएडिक चर (बचाव का पर्याय) जैसे नाम सामने आते हैं। कार्यात्मक प्रोग्रामिंग और शब्द पुनर्लेखन में चर शब्द के दोहरे अर्थ और तर्कों और चर के बीच अंतर पर ध्यान दें। उदाहरण के लिए, एक शब्द (कार्य) में तीन चर हो सकते हैं, उनमें से एक बचाव है, इस प्रकार शब्द को तीन या अधिक तर्क लेने की अनुमति मिलती है (या यदि बचाव को खाली होने की अनुमति दी जाती है तो दो या अधिक)।
उदाहरण
सी में
C (प्रोग्रामिंग लैंग्वेज) में वैरिएडिक फ़ंक्शन को सुवाह्य रूप से लागू करने के लिए, मानक stdarg.h|stdarg.h हेडर पंक्ति का उपयोग किया जाता है. पुराने varargs.h|varargs.h हेडर के पक्ष में अस्वीकृत कर दिया गया है stdarg.h. C++ में, हेडर पंक्ति cstdarg प्रयोग किया जाता है।[4]
#include <stdarg.h>
#include<stdio.h>
double average(int count, ...) {
va_list ap;
int j;
double sum = 0;
va_start(ap, count); /* Before C23: Requires the last fixed parameter (to get the address)*/
for (j = 0; j < count; j++) {
sum += va_arg(ap, int); /* Increments ap to the next argument. */
}
va_end(ap);
return sum / count;
}
int main(int argc, char const *argv[]) {
printf("%f\n", average(3, 1, 2, 3));
return 0;
}
यह तर्कों की मनमानी संख्या के औसत की गणना करेगा। ध्यान दें कि कार्यों तर्कों की संख्या या उनके प्रकारों को नहीं जानता है। उपरोक्त कार्य अपेक्षा करता है कि प्रकार int होंगे , और तर्कों की संख्या पहले तर्क में पारित की जाएगी (यह एक लगातार उपयोग है लेकिन लैंग्वेज या संकलनकर्ता द्वारा किसी भी तरह से लागू नहीं किया गया है)। कुछ अन्य मामलों में, उदाहरण के लिए मुद्रण , एक प्रारूप तार से तर्कों की संख्या और प्रकार का पता लगाया जाता है। दोनों ही मामलों में, यह प्रोग्रामर पर निर्भर करता है कि वह सही जानकारी प्रदान करे। (वैकल्पिक रूप से, संख्या इंगित करने के लिए NULL जैसे प्रहरी मान का उपयोग किया जा सकता है।) यदि कार्य की अपेक्षा से कम तर्क पारित किए जाते हैं, या तर्क के प्रकार गलत हैं, तो यह इसे मेमोरी के अमान्य क्षेत्रों में पढ़ने का कारण बन सकता है और प्रारूप तार हमले जैसी कमजोरियों को जन्म दे सकता है। .
stdarg.h एक प्रकार घोषित करता है, va_list, और चार मैक्रोज़ को परिभाषित करता है:va_start, va_arg,va_copy, औरva_end. प्रत्येक मंगलाचरण va_start और va_copy के अनुरूप मंगलाचरण से मेल खाना चाहिए va_end. परिवर्तनीय तर्कों के साथ काम करते समय, एक कार्य सामान्यता एक प्रकार का चर घोषित करता है va_list (ap उदाहरण में) जिसे वृहत् द्वारा कुशलतापूर्वक किया जाएगा।
va_startदो तर्क लेता है, ava_listऑब्जेक्ट और कार्य के अंतिम प्राचल का संदर्भ (अध्याहार से पहले वाला; बहुत बड़ा इसका उपयोग अपने चाल प्राप्त करने के लिए करता है)। C23 में, दूसरे तर्क की अब आवश्यकता नहीं होगी और वैरिएडिक फ़ंक्शन को दीर्घवृत्त से पहले नामित प्राचल की आवश्यकता नहीं होगी।[5] यह आरंभ करता हैva_listद्वारा उपयोग के लिए वस्तुva_argयाva_copy. यदि संदर्भ गलत है तो संकलनकर्ता सामान्यता एक चेतावनी जारी करेगा (उदाहरण के लिए पिछले प्राचल से भिन्न प्राचल का संदर्भ, या पूरी तरह से अलग ऑब्जेक्ट का संदर्भ), लेकिन संकलन को सामान्य रूप से पूरा होने से नहीं रोकेगा।va_argदो तर्क लेता है, एकva_listऑब्जेक्ट (पहले प्रारंभ किया गया) और एक प्रकार का वर्णनकर्ता। यह अगले चर तर्क तक विस्तारित होता है, और इसमें निर्दिष्ट प्रकार होता है। का क्रमिक आह्वानva_argप्रत्येक परिवर्तनीय तर्क को बारी-बारी से संसाधित करने की अनुमति दें। अनिर्दिष्ट व्यवहार तब होता है जब प्रकार गलत है या कोई अगला चर तर्क नहीं है।va_endएक तर्क लेता है, एकva_listवस्तु। यह साफ़ करने का काम करता है. उदाहरण के लिए, यदि कोई चर तर्कों को एक से अधिक बार अवलोकन करना चाहता है, तो प्रोग्रामर आपका पुनः आरंभ करेगाva_listआह्वान द्वारा वस्तुva_endऔर तबva_startफिर से उस पर.va_copyदो तर्क लेता है, दोनोंva_listवस्तुएं। यह दूसरे को (जिसे प्रारंभ किया गया होगा) पहले में प्रतिरूप करता है। एक से अधिक उदाहरणों में परिवर्तनीय तर्कों को अवलोकन करने पर वापस जाकर, इसे लागू करके प्राप्त किया जा सकता हैva_startपहले परva_list, फिर उपयोग करनाva_copyइसे एक सेकंड में प्रतिरूप करने के लिएva_list. परिवर्तनीय तर्कों को पहली बार अवलोकन करने के बादva_argऔर पहलाva_list(इसके साथ इसका निपटानva_end), प्रोग्रामर चर तर्कों को दूसरी बार अवलोकन कर सकता हैva_argऔर दूसराva_list.va_endको प्रतिरूप पर भी कॉल करने की आवश्यकता हैva_listयुक्त कार्य के वापस आने से पहले।
C# में
सी पार्श्व संकेतशब्द का उपयोग करके वैरिएडिक फ़ंक्शन का वर्णन करता है।, तर्कों के लिए एक प्रकार प्रदान किया जाना चाहिए हालांकि object[] का उपयोग अर्थबोधक के रूप में उपयोग किया जा सकता है। आजीविका स्थान पर, आप या तो तर्कों को एक-एक करके सूचीबद्ध कर सकते हैं, या आवश्यक तत्व प्रकार वाले पहले से मौजूद सरणी को सौंप सकते हैं। वैरिएडिक रूप का उपयोग बाद के लिए वाक्यात्मक शर्करा है।
प्रणाली का उपयोग करना;
कक्षा कार्यक्रम
{
static int Foo(int a, int b, params int[] args)
{
// Return the sum of the integers in args, ignoring a and b. int sum = 0;
foreach (int i in args)
sum + = मैं;
return sum;
}
static void Main(string[] args)
{
Console.WriteLine(Foo(1,2)); // 0
Console.WriteLine(Foo(1, 2, 3, 10, 20)); //33
int[] manyValues = new int[] {13, 14, 15 };
Console.WriteLine(Foo(1,2, manyValues)); //42
}
}
C++ में
C++ में बुनियादी विविधतापूर्ण सुविधा बहुत हद तक C के समान है। एकमात्र अंतर वाक्य रचना में है, जहां दीर्घवृत्त से पहले अल्पविराम को छोड़ा जा सकता है। C++ नामित मापदंडों के बिना वैरिएडिक फ़ंक्शन की अनुमति देता है लेकिन तब से उन तर्कों तक पहुंचने का कोई तरीका प्रदान नहीं करता है va_start कार्य के अंतिम निश्चित तर्क के नाम की आवश्यकता है।
- include <iostream>
- include <cstdarg>
void simple_printf(const char* fmt...) // C-style const char* fmt, ... is also valid
{
va_list args;
va_start(args, fmt);
while (*fmt != '\0') {
if (*fmt == 'd') {
int i = va_arg(args, int);
std::cout << i << '\n';
} else if (*fmt == 'c') {
// note automatic conversion to integral type
int c = va_arg(args, int);
std::cout << static_cast<char>(c) << '\n';
} else if (*fmt == 'f') {
double d = va_arg(args, double);
std::cout << d << '\n';
}
++ fmt;
}
va_end(args);
}
int main()
{
simple_printf(dcff, 3, 'a', 1.999, 42.5);
}
वैरिएडिक नमूना (पैरामीटर पैक) का उपयोग C++ में अंतर्निहित लैंग्वेज (उच्च-क्रम कार्य) के साथ भी किया जा सकता है।
- include <iostream>
template <typename... Ts>
void foo_print(Ts... args)
{
((std::cout << args << ), ...);
}
int main()
{
std::cout << std::boolalpha; foo_print(1, 3.14f); // 1 3.14 foo_print(Foo, 'b', true, nullptr); // Foo b true nullptr
}
सी++ के लिए सीईआरटी कोडिंग मानक दुरुपयोग के कम जोखिम के कारण सी-स्टाइल वैरिएडिक फ़ंक्शन की तुलना में सी++ में वैरिएडिक नमूना (पैरामीटर पैक) के उपयोग को दृढ़ता से प्राथमिकता देते हैं।[6]
गो में
गो (प्रोग्रामिंग लैंग्वेज) में वैरिएडिक फ़ंक्शन को किसी भी संख्या में अनुगामी तर्कों के साथ बुलाया जा सकता है।[7] fmt.Println एक सामान्य वैरिएडिक फ़ंक्शन है; यह कैच-ऑल प्रकार के रूप में एक खाली अंतराफलक का उपयोग करता है।
package main
import "fmt"
// This variadic function takes an arbitrary number of ints as arguments.
func sum(nums ...int) {
fmt.Print("The sum of ", nums) // Also a variadic function.
.
sum := 0
for _, num := range nums {
total += num
}
fmt.Println(" is", total) // Also a variadic function.
}
func main() {
// Variadic functions can be called in the usual way with individual
// arguments.
sum(1, 2) // "The sum of [1 2] is 3"
sum(1, 2, 3) // "The sum of [1 2 3] is 6"
// If you already have multiple args in a slice, apply them to a variadic
// function using func(slice...) like this.
nums := []int{1, 2, 3, 4}
sum(nums...) // "The sum of [1 2 3 4] is 10"
}
आउटपुट:
कुल मिलाकर [1 2] का योग 3 है
कुल मिलाकर [1 2 3] का योग 6 है
कुल मिलाकर [1 2 3 4] का योग 10 है
जावा में
C# की तरह, जावा (प्रोग्रामिंग लैंग्वेज) में } प्रकार कैच-ऑल के रूप में उपलब्ध है।
public class Program {
// Variadic methods store any additional arguments they receive in an array.
// Consequentially, `printArgs` is actually a method with one parameter: a
// variable-length array of `String`s.
private static void printArgs(String... strings) {
for (String string : strings) {
System.out.println(string);
}
}
public static void main(String[] args) {
printArgs("hello"); // short for printArgs(["hello"])
printArgs("hello", "world"); // short for printArgs(["hello", "world"])
}
}
जावास्क्रिप्ट में
जावास्क्रिप्ट विभिन्न प्रकार के तर्कों की परवाह नहीं करता है।
function sum(...numbers) {
return numbers.reduce((a, b) => a + b, 0);
}
console.log(sum(1, 2, 3)); // 6
console.log(sum(3, 2)); // 5
console.log(sum()); // 0
तर्क ऑब्जेक्ट का उपयोग करके एक वैरिएडिक फ़ंक्शन बनाना भी संभव है, हालांकि यह केवल प्रकार्य संकेतशब्द के साथ बनाए गए प्रकार्य के साथ प्रयोग करने योग्य है।
function sum() {
return Array.prototype.reduce.call(arguments, (a, b) => a + b, 0);
}
console.log(sum(1, 2, 3)); // 6
console.log(sum(3, 2)); // 5
console.log(sum()); // 0
लुआ (प्रोग्रामिंग लैंग्वेज) में
लुआ (प्रोग्रामिंग लैंग्वेज) प्रकार्य वापसी संकेतशब्द का उपयोग करके अन्य मानों की तरह ही अन्य प्रकार्य में वेरार्ग पास कर सकते हैं। लूआ संस्करण 5.2 या उच्चतर का उपयोग करके तालिकाओं को वैरिएडिक फ़ंक्शन में पारित किया जा सकता है[8] table.unpack, या लुआ 5.1 या उससे कम[9] unpack. वेरार्ग को एक मान के रूप में वेरार्ग के साथ एक तालिका बनाकर उपयोग किया जा सकता है।
function sum(...) --... designates varargs
local sum=0
for _,v in pairs({...}) do --creating a table with a varargs is the same as creating one with standard values
sum=sum+v
end
return sum
end
values={1,2,3,4}
sum(5,table.unpack(values)) --returns 15. table.unpack should go after any other arguments, otherwise not all values will be passed into the function.
function add5(...)
return ...+5 --this is incorrect usage of varargs, and will only return the first value provided
end
entries={}
function process_entries()
local processed={}
for i,v in pairs(entries) do
processed[i]=v --placeholder processing code
end
return table.unpack(processed) --returns all entries in a way that can be used as a vararg
end
print(process_entries()) --the print function takes all varargs and writes them to stdout separated by newlines
पास्कल (प्रोग्रामिंग लैंग्वेज) में
पास्कल (प्रोग्रामिंग लैंग्वेज) में चार अंतर्निहित प्रक्रियाएं हैं जिन्हें वैरिएडिक के रूप में परिभाषित किया गया है, जो इस विशेष स्थिति के कारण, संकलक के लिए आंतरिक हैं। ये हैं पढ़ें, readln, लिखें, और writeln प्रक्रियाएं. हालाँकि, प्रक्रियाओं या कार्यों के लिए डिफ़ॉल्ट तर्क की अनुमति देने वाले वैकल्पिक विनिर्देश हैं जो उन्हें वैरिएडिक रूप से काम करते हैं, साथ ही बहुरूपता (कंप्यूटर विज्ञान)भी है जो एक प्रक्रिया या प्रकार्य को अलग-अलग पैरामीटर रखने की अनुमति देता है। वह read[ln] और write[ln] सभी प्रक्रियाओं का प्रारूप समान है:
पढ़ें[एलएन] [( [फ़ाइल ,] चर [, चर ...] )] ;
लिखें[एलएन] [( [फ़ाइल][, मूल्य [, मूल्य ...] )] ;
कहाँ
fileएक वैकल्पिक फ़ाइल चर है, जिसे यदि छोड़ दिया जाए तो यह डिफ़ॉल्ट हो जाता हैinputके लिएreadऔरreadln, या डिफ़ॉल्टoutputके लिएwriteऔरwriteln;variableएक अदिश राशि है जैसे कि चार (वर्ण), पूर्णांक, या वास्तविक (या कुछ संकलक के लिए, कुछ रिकॉर्ड प्रकार या सरणी प्रकार जैसे स्ट्रिंग); औरvalueएक चर या स्थिरांक है।
उदाहरण:
var
f: text;
ch: ;char
n,a,I,B: Integer;
S: String;
begin
Write('Enter name of file to write results: ');
readln(s);
assign(f,S);
rewrite(f);
Write('What is your name? ');
readln(Input,S);
Write('Hello, ',S,'! Enter the number of calculations you want to do:');
writeln(output);
Write('? ');
readln(N);
Write('For each of the ',n,' formulas, enter ');
write('two integers separated by one or more spaces');
writeln;
for i := 1 to N do
begin
Write('Enter pair #',i,'? ');
read(a,b);
READLN;
WRITELN(Out,'A [',a,'] + B [',B,'] =',A+B);
end;
close(OUT);
end.
उपरोक्त उदाहरण में, जहां तक संकलक का सवाल है, लाइनें 9 और 13 समान हैं, क्योंकि यदि input फ़ाइल चर को read या readln कथन द्वारा पढ़ा जा रहा है तो फ़ाइल चर को छोड़ा जा सकता है। साथ ही, संकलक पंक्ति 15 और 20 को समान मानता है, क्योंकि यदि फ़ाइल चर को outputमें लिखा जा रहा है ,तो इसे छोड़ा जा सकता है, जिसका अर्थ है (पंक्ति 20 पर) क्योंकि प्रक्रिया में कोई तर्क पारित नहीं किया जा रहा है, कोष्ठक तर्कों को सूचीबद्ध करते हैं मिटाया जा सकता है। पंक्ति 26 से पता चलता है कि writeln कथन में किसी भी संख्या में तर्क हो सकते हैं, और वे एक उद्धृत स्ट्रिंग, एक चर, या यहां तक कि एक सूत्र परिणाम भी हो सकते हैं।
ऑब्जेक्ट पास्कल बहुरूपी प्रक्रियाओं और कार्यों का समर्थन करता है, जहां विभिन्न प्रक्रियाओं या कार्यों का एक ही नाम हो सकता है लेकिन उन्हें दिए गए तर्कों से अलग किया जा सकता है।
पास्कल अनुपस्थिति तर्कों का भी समर्थन करता है, जहां तर्क का मान, यदि प्रदान नहीं किया गया है, तो एक अनुपस्थिति मान दिया जाता है।
पहले उदाहरण के लिए, बहुरूपता, निम्नलिखित पर विचार करें:
function add(a1,a2:integer):Integer; begin add := a1+a2 end;
function add(r1,r2:real):real; begin add := a1+a2 end;
function add(a1:integer;r2:real):real; begin add := real(a1)+a2 end;
function add(r1:real,a2:integer):real; begin add := a1+real(a2) end;
उपरोक्त उदाहरण में, यदि दो पूर्णांक मानों के साथ कोadd कहा जाता है, पंक्ति 1 पर घोषित प्रकार्य को बुलाया जाएगा; यदि तर्कों में से एक पूर्णांक है और एक वास्तविक है, तो पंक्ति 3 या 4 पर प्रकार्य को कॉल किया जाता है, जो इस पर निर्भर करता है कि कौन सा पूर्णांक है। यदि दोनों वास्तविक हैं, तो पंक्ति 2 पर प्रकार्य को कॉल किया जाता है।
अनुपस्थिति पैरामीटर के लिए, निम्नलिखित पर विचार करें:
const
Three = 3;
var
K: Integer;
function add(i1: integer = 0;
i2: integer = 0;
i3: integer = 0;
i4: integer = 0;
i5: integer = 0;
i6: integer = 0;
i7: integer = 0;
i8: integer = 0): integer;
begin
add := i1+i2+i3+I4+I5+i6+I7+I8;
end;
begin
K := add; { K is 0}
K := add(K,1); { K is 1}
K := add(1,2); { K is 3}
K := add(1,2,Three); { K is 6, etc.}
end.
पंक्ति 6 पर, (और नीचे की पंक्तियाँ में) पैरामीटर = 0 संकलक को बताता है, "यदि कोई तर्क प्रदान नहीं किया गया है, तो तर्क को शून्य मानें"। पंक्ति 19 पर, कोई तर्क नहीं दिया गया, इसलिए प्रकार्य 0 लौटाता है। लाइन 20 पर, किसी भी तर्क के लिए या तो एक संख्या या एक चर प्रदान किया जा सकता है, और जैसा कि लाइन 22 पर दिखाया गया है, एक स्थिरांक।
पीएचपी में
जब तक तर्क टाइप नहीं किया जाता है तब तक PHP विभिन्न प्रकार के तर्कों की परवाह नहीं करता है।
function sum(...$nums): int
{
return array_sum($nums);
}
echo sum(1, 2, 3); // 6
और वैरिएडिक तर्क टाइप किए:
function sum(int ...$nums): int
{
return array_sum($nums);
}
echo sum(1, 'a', 3); // TypeError: Argument 2 passed to sum() must be of the type int (since PHP 7.3)
पायथन में
पायथन (प्रोग्रामिंग लैंग्वेज) विभिन्न प्रकार के तर्कों की परवाह नहीं करता है।
def foo(a, b, *args):
print(args) # args is a tuple (immutable sequence).
foo(1, 2) # ()
foo(1, 2, 3) # (3,)
foo(1, 2, 3, "hello") # (3, "hello")
कीवर्ड तर्कों को शब्दकोश में संग्रहित किया जा सकता है, उदा. def bar(*args, **kwargs).
रकु में
राकू (प्रोग्रामिंग लैंग्वेज) में, विभिन्न प्रकार के प्रकार्य बनाने वाले पैरामीटर के प्रकार को स्लर्पी एरे पैरामीटर के रूप में जाना जाता है और उन्हें तीन समूहों में वर्गीकृत किया जाता है:
चपटा घोल
इन मापदंडों को एक एकल तारांकन (*) के साथ घोषित किया जाता है और वे तत्वों की एक या अधिक परतों को भंग करके तर्कों को समतल करते हैं जिन्हें पुनरावृत्त किया जा सकता है (यानी, Iterables))।
sub foo($a, $b, *@args) {
say @args.perl;
}
foo(1,2) # []
foo(1,2,3) # [3]
foo(1, 2, 3, "hello" ) # [3 "hello" ]
foo(1, 2, 3, [4, 5], [6]); # [3, 4, 5, 6]
बिना चपटा घोल
ये पैरामीटर दो तारांकन () के साथ घोषित किए गए हैं और वे सूची के अंदर किसी भी पुनरावृत्त तर्क को समतल नहीं करते हैं, लेकिन तर्क को कमोबेश वैसे ही रखते हैं:
sub bar($a, $b, **@args) {
say @args.perl;
}
bar(1,2); # []
bar(1, 2, 3); #[3]
bar(1, 2, 3, "hello" ); # [3 "hello" ]
bar(1, 2, 3, [4, 5], [6]); # [3, [4, 5], [6]]
प्रासंगिक घिनौना
इन मापदंडों को प्लस (+) चिह्न के साथ घोषित किया जाता है और वे "एकल तर्क नियम लागू करते हैं जो यह तय करता है कि संदर्भ के आधार पर गंदे तर्क को कैसे संभालना है। सीधे शब्दों में कहें, यदि केवल एक ही तर्क पारित किया जाता है और वह तर्क पुनरावृत्त होता है, तो वह तर्क है स्लरी पैरामीटर सरणी को भरने के लिए उपयोग किया जाता है। किसी अन्य मामले में, +@ जैसे काम करता है **@ (अर्थात, बिना चपटा घोल)।
sub zaz($a, $b, +@args) {
say @args.perl;
}
zaz(1, 2); # []
zaz(1, 2, 3); #[3]
zaz(1, 2, 3, "hello"); # [3 "hello" ]
zaz(1, 2, [4, 5]); # [4, 5], single argument fills up array
zaz(1, 2, 3, [4, 5]); # [3, [4, 5, **behaving as **@
zaz(1, 2, 3, [4, 5], [6]); # [3, [4, 5], [6, **behaving as **@
रूबी में
रूबी (प्रोग्रामिंग लैंग्वेज) विभिन्न प्रकार के तर्कों की परवाह नहीं करती है।
def foo(*args)
print args
end
foo(1)
# prints `[1]=> nil`
foo(1, 2)
# prints `[1, 2]=> nil`
जंग में
ज़ंग (प्रोग्रामिंग लैंग्वेज) प्रकार्य में वैरिएडिक तर्कों का समर्थन नहीं करता है। इसके अतिरिक्त, यह मैक्रो (कंप्यूटर विज्ञान) का उपयोग करता है।[10]
macro_rules! calculate {
// The pattern for a single `eval`
(eval $e:expr) => {{
{
let val: usize = $e; // Force types to be integers
println!("{} = {}", stringify!{$e}, val);
}
}};
// Decompose multiple `eval`s recursively
(eval $e:expr, $(eval $es:expr),+) => {{
calculate! { eval $e }
calculate! { $(eval $es),+ }
}};
}
fn main() {
calculate! { // Look ma! Variadic `calculate!`!
eval 1 + 2,
eval 3 + 4,
eval (2 * 3) + 1
}
}
जंग एक c_variadic फीचर स्विच के माध्यम से C के वैरिएडिक प्रणाली के साथ बातचीत करने में सक्षम है। अन्य C इंटरफेस की तरह, सिस्टम को जंग के लिए unsafe माना जाता है।[11]
स्काला में
object Program {
// Variadic methods store any additional arguments they receive in an array.
// Consequentially, `printArgs` is actually a method with one parameter: a
// variable-length array of `String`s.
private def printArgs(strings: String*): Unit = {
strings.foreach(println)
}
def main(args: Array[String]): Unit = {
printArgs("hello"); // short for printArgs(["hello"])
printArgs("hello", "world"); // short for printArgs(["hello", "world"])
}
}
स्विफ्ट में
स्विफ्ट (प्रोग्रामिंग लैंग्वेज) विभिन्न प्रकार के तर्कों की परवाह करती है, लेकिन सभी को पकड़ती है Any प्रकार उपलब्ध है.
func greet(timeOfTheDay: String, names: String...) {
// here, names is [String]
print("Looks like we have \(names.count) people")
for name in names {
print("Hello \(name), good \(timeOfTheDay)")
}
}
greet(timeOfTheDay: "morning", names: "Joseph", "Clara", "William", "Maria")
// Output:
// Looks like we have 4 people
// Hello Joseph, good morning
// Hello Clara, good morning
// Hello William, good morning
// Hello Maria, good morning
टी.सी.एल में
एक टीसीएल प्रक्रिया या लैम्ब्डा तब वैरिएडिक होती है जब इसका अंतिम तर्क argsहोता है : इसमें शेष सभी तर्कों की एक सूची (संभवतः खाली) होगी। यह पैटर्न कई अन्य प्रक्रिया-जैसी विधियों में आम है।[12][13]
proc greet {timeOfTheDay args} {
puts "Looks like we have [llength $args] people"
foreach name $args {
puts "Hello $name, good $timeOfTheDay"
}
}
greet "morning" "Joseph" "Clara" "William" "Maria"
# Output:
# Looks like we have 4 people
# Hello Joseph, good morning
# Hello Clara, good morning
# Hello William, good morning
# Hello Maria, good morning
यह भी देखें
- जावा सिंटैक्स#Varargs
- वैरिएडिक स्थूल (सी प्रोग्रामिंग लैंग्वेज)
- वैरिएडिक टेम्पलेट
टिप्पणियाँ
संदर्भ
- ↑ Henry S. Leonard and H. N. Goodman, A calculus of individuals. Abstract of a talk given at the Second Meeting of the Association for Symbolic Logic, held in Cambridge MA on December 28–30, 1936, [1], Journal of Symbolic Logic 2(1) 1937, 63.
- ↑ Klemens, Ben (2014). 21st Century C: C Tips from the New School. O'Reilly Media, Inc. p. 224. ISBN 978-1491904442.
- ↑ CLP (H): Constraint Logic Programming for Hedges
- ↑ "<cstdarg> (stdarg.h) - C++ Reference". www.cplusplus.com.
- ↑ Gilding, Alex; Meneide, JeanHeyd (2022-04-15). "WG14-N2975 : Relax requirements for variadic parameter lists, v3" (PDF).
- ↑ "DCL50-CPP. Do not define a C-style variadic function".
- ↑ "Go by Example: Variadic Functions".
- ↑ "Lua 5.2 Reference Manual". www.lua.org. Retrieved 2023-02-05.
- ↑ "Lua 5.1 Reference Manual". www.lua.org. Retrieved 2023-02-05.
- ↑ "विविधता". Rust By Example.
- ↑ "2137-variadic". The Rust RFC Book.
- ↑ "प्रोक मैनुअल पेज". Tcl/Tk Documentation.
- ↑ "तर्क". Tcler's Wiki.
बाहरी संबंध
- Variadic function. Rosetta Code task showing the implementation of variadic functions in over fifty programming languages.
- Variable Argument Functions — A tutorial on Variable Argument Functions for C++
- GNU libc manual