स्कैनफ़ प्रारूप स्ट्रिंग: Difference between revisions

From Vigyanwiki
(Created page with "{{Short description|Control parameter used in programming languages}} {{lowercase}} {{More citations needed|date=May 2010}} {{Use dmy dates|date=November 2020}} एक स्...")
 
No edit summary
Line 1: Line 1:
{{Short description|Control parameter used in programming languages}}
{{Short description|Control parameter used in programming languages}}
{{lowercase}}
एक स्कैनएफ प्रारूप स्ट्रिंग (''स्कैन एफ''ऑर्मेटेड) एक इनपुट [[स्ट्रिंग (कंप्यूटर विज्ञान)]] के लेआउट को निर्दिष्ट करने के लिए विभिन्न [[फ़ंक्शन (कंप्यूटर विज्ञान)]] में उपयोग किया जाने वाला एक नियंत्रण पैरामीटर है। फ़ंक्शंस तब स्ट्रिंग को विभाजित कर सकते हैं और उचित [[डेटा प्रकार]]ों के मानों में अनुवाद कर सकते हैं। स्ट्रिंग स्कैनिंग फ़ंक्शंस अक्सर मानक [[ पुस्तकालय (कंप्यूटिंग) |पुस्तकालय (कंप्यूटिंग)]] में प्रदान किए जाते हैं। स्कैनफ़ एक फ़ंक्शन है जो मानक इनपुट स्ट्रिंग से स्वरूपित डेटा को पढ़ता है, जो आमतौर पर कीबोर्ड होता है और जब भी निर्दिष्ट तर्कों में बुलाया जाता है तो परिणाम लिखता है।
{{More citations needed|date=May 2010}}
{{Use dmy dates|date=November 2020}}
एक स्कैनएफ प्रारूप स्ट्रिंग (''स्कैन एफ''ऑर्मेटेड) एक इनपुट [[स्ट्रिंग (कंप्यूटर विज्ञान)]] के लेआउट को निर्दिष्ट करने के लिए विभिन्न [[फ़ंक्शन (कंप्यूटर विज्ञान)]] में उपयोग किया जाने वाला एक नियंत्रण पैरामीटर है। फ़ंक्शंस तब स्ट्रिंग को विभाजित कर सकते हैं और उचित [[डेटा प्रकार]]ों के मानों में अनुवाद कर सकते हैं। स्ट्रिंग स्कैनिंग फ़ंक्शंस अक्सर मानक [[ पुस्तकालय (कंप्यूटिंग) ]] में प्रदान किए जाते हैं। स्कैनफ़ एक फ़ंक्शन है जो मानक इनपुट स्ट्रिंग से स्वरूपित डेटा को पढ़ता है, जो आमतौर पर कीबोर्ड होता है और जब भी निर्दिष्ट तर्कों में बुलाया जाता है तो परिणाम लिखता है।


स्कैनएफ शब्द सी मानक लाइब्रेरी से आया है, जिसने इस प्रकार के फ़ंक्शन को लोकप्रिय बनाया, लेकिन ऐसे फ़ंक्शन सी से पहले के हैं, और अन्य नामों का उपयोग किया जाता है, जैसे <code>readf</code> [[ALGOL 68]] में। स्कैनफ प्रारूप स्ट्रिंग्स, जो स्वरूपित इनपुट ([[ पदच्छेद ]]) प्रदान करते हैं, [[प्रिंटफ प्रारूप स्ट्रिंग]]्स के पूरक हैं, जो स्वरूपित आउटपुट ([[टेम्पलेटिंग भाषा]]) प्रदान करते हैं। ये अधिक परिष्कृत और लचीले पार्सर या टेम्पलेट इंजन की तुलना में सरल कार्यक्षमता और निश्चित प्रारूप प्रदान करते हैं, लेकिन कई उद्देश्यों के लिए पर्याप्त हैं।
स्कैनएफ शब्द सी मानक लाइब्रेरी से आया है, जिसने इस प्रकार के फ़ंक्शन को लोकप्रिय बनाया, लेकिन ऐसे फ़ंक्शन सी से पहले के हैं, और अन्य नामों का उपयोग किया जाता है, जैसे <code>readf</code> [[ALGOL 68]] में। स्कैनफ प्रारूप स्ट्रिंग्स, जो स्वरूपित इनपुट ([[ पदच्छेद ]]) प्रदान करते हैं, [[प्रिंटफ प्रारूप स्ट्रिंग]]्स के पूरक हैं, जो स्वरूपित आउटपुट ([[टेम्पलेटिंग भाषा]]) प्रदान करते हैं। ये अधिक परिष्कृत और लचीले पार्सर या टेम्पलेट इंजन की तुलना में सरल कार्यक्षमता और निश्चित प्रारूप प्रदान करते हैं, लेकिन कई उद्देश्यों के लिए पर्याप्त हैं।
Line 11: Line 8:




==उपयोग== <code>scanf</code> ई> फ़ंक्शन, जो [[सी प्रोग्रामिंग भाषा]] में पाया जाता है, [[मानक इनपुट]] (अक्सर एक [[कमांड लाइन इंटरफेस]] या समान प्रकार का [[टेक्स्ट यूजर इंटरफ़ेस]]) से संख्याओं और अन्य [[ डेटा प्रकार ]] के लिए इनपुट पढ़ता है।
==उपयोग== <code>scanf</code> ई> फ़ंक्शन, जो [[सी प्रोग्रामिंग भाषा]] में पाया जाता है, [[मानक इनपुट]] (अक्सर एक [[कमांड लाइन इंटरफेस]] या समान प्रकार का [[टेक्स्ट यूजर इंटरफ़ेस]]) से संख्याओं और अन्य [[ डेटा प्रकार |डेटा प्रकार]] के लिए इनपुट पढ़ता है।


निम्नलिखित सी कोड मानक इनपुट स्ट्रीम से अस्वरूपित दशमलव [[पूर्णांक]]ों की एक चर संख्या को पढ़ता है और उनमें से प्रत्येक को अलग-अलग पंक्तियों में प्रिंट करता है:
निम्नलिखित सी कोड मानक इनपुट स्ट्रीम से अस्वरूपित दशमलव [[पूर्णांक]]ों की एक चर संख्या को पढ़ता है और उनमें से प्रत्येक को अलग-अलग पंक्तियों में प्रिंट करता है:
Line 31: Line 28:
  456 123 789 456 12
  456 123 789 456 12
  456 1
  456 1
      2378
    2378


लगातार अंतराल पर इस प्रकार दिखाई देगा:
लगातार अंतराल पर इस प्रकार दिखाई देगा:
Line 57: Line 54:
}
}
</syntaxhighlight>
</syntaxhighlight>
इससे कोई फर्क नहीं पड़ता कि प्रोग्रामर किस डेटा प्रकार को पढ़ना चाहता है, तर्क (जैसे <code>&n</code> ऊपर) मेमोरी की ओर इंगित करने वाला [[ सूचक (कंप्यूटर प्रोग्रामिंग) ]] होना चाहिए। अन्यथा, फ़ंक्शन सही ढंग से प्रदर्शन नहीं करेगा क्योंकि यह उस वेरिएबल के मेमोरी स्थान को इंगित करने के बजाय मेमोरी के गलत अनुभागों को ओवरराइट करने का प्रयास करेगा जिसके लिए आप इनपुट प्राप्त करने का प्रयास कर रहे हैं।
इससे कोई फर्क नहीं पड़ता कि प्रोग्रामर किस डेटा प्रकार को पढ़ना चाहता है, तर्क (जैसे <code>&n</code> ऊपर) मेमोरी की ओर इंगित करने वाला [[ सूचक (कंप्यूटर प्रोग्रामिंग) |सूचक (कंप्यूटर प्रोग्रामिंग)]] होना चाहिए। अन्यथा, फ़ंक्शन सही ढंग से प्रदर्शन नहीं करेगा क्योंकि यह उस वेरिएबल के मेमोरी स्थान को इंगित करने के बजाय मेमोरी के गलत अनुभागों को ओवरराइट करने का प्रयास करेगा जिसके लिए आप इनपुट प्राप्त करने का प्रयास कर रहे हैं।


अंतिम उदाहरण में ऑपरेटर का पता (<code>&</code>) का उपयोग तर्क के लिए नहीं किया जाता है: जैसा <code>word</code> की एक सारणी डेटा संरचना का नाम है <code>char</code>, इस प्रकार यह (सभी संदर्भों में जिसमें यह किसी पते का मूल्यांकन करता है) सरणी के पहले तत्व के सूचक के बराबर है। जबकि अभिव्यक्ति <code>&word</code> संख्यात्मक रूप से समान मूल्य पर मूल्यांकन करेगा, शब्दार्थ की दृष्टि से, इसका एक बिल्कुल अलग अर्थ है कि यह इसके एक तत्व के बजाय पूरे सरणी के पते को दर्शाता है। नियुक्ति करते समय इस तथ्य को ध्यान में रखा जाना चाहिए <code>scanf</code> स्ट्रिंग्स के लिए आउटपुट।
अंतिम उदाहरण में ऑपरेटर का पता (<code>&</code>) का उपयोग तर्क के लिए नहीं किया जाता है: जैसा <code>word</code> की एक सारणी डेटा संरचना का नाम है <code>char</code>, इस प्रकार यह (सभी संदर्भों में जिसमें यह किसी पते का मूल्यांकन करता है) सरणी के पहले तत्व के सूचक के बराबर है। जबकि अभिव्यक्ति <code>&word</code> संख्यात्मक रूप से समान मूल्य पर मूल्यांकन करेगा, शब्दार्थ की दृष्टि से, इसका एक बिल्कुल अलग अर्थ है कि यह इसके एक तत्व के बजाय पूरे सरणी के पते को दर्शाता है। नियुक्ति करते समय इस तथ्य को ध्यान में रखा जाना चाहिए <code>scanf</code> स्ट्रिंग्स के लिए आउटपुट।
Line 77: Line 74:
* <code>%x</code>, <code>%X</code> : एक पूर्णांक को अहस्ताक्षरित हेक्साडेसिमल संख्या के रूप में स्कैन करें।
* <code>%x</code>, <code>%X</code> : एक पूर्णांक को अहस्ताक्षरित हेक्साडेसिमल संख्या के रूप में स्कैन करें।
* <code>%o</code> : एक पूर्णांक को अष्टक संख्या के रूप में स्कैन करें।
* <code>%o</code> : एक पूर्णांक को अष्टक संख्या के रूप में स्कैन करें।
* <code>%s</code> : एक [[ वर्ण स्ट्रिंग ]] को स्कैन करें. स्कैन व्हाइटस्पेस (कंप्यूटर विज्ञान) पर समाप्त होता है। स्ट्रिंग के अंत में एक [[शून्य वर्ण]] संग्रहीत होता है, जिसका अर्थ है कि आपूर्ति किया गया बफ़र निर्दिष्ट इनपुट लंबाई से कम से कम एक वर्ण लंबा होना चाहिए।
* <code>%s</code> : एक [[ वर्ण स्ट्रिंग |वर्ण स्ट्रिंग]] को स्कैन करें. स्कैन व्हाइटस्पेस (कंप्यूटर विज्ञान) पर समाप्त होता है। स्ट्रिंग के अंत में एक [[शून्य वर्ण]] संग्रहीत होता है, जिसका अर्थ है कि आपूर्ति किया गया बफ़र निर्दिष्ट इनपुट लंबाई से कम से कम एक वर्ण लंबा होना चाहिए।
* <code>%c</code> : एक अक्षर (चार) को स्कैन करें। कोई शून्य वर्ण नहीं जोड़ा गया है.
* <code>%c</code> : एक अक्षर (चार) को स्कैन करें। कोई शून्य वर्ण नहीं जोड़ा गया है.
* व्हाइटस्पेस (कंप्यूटर विज्ञान): कोई भी व्हाइटस्पेस वर्ण शून्य या अधिक व्हाइटस्पेस (कंप्यूटर विज्ञान) वर्णों के लिए स्कैन ट्रिगर करता है। रिक्त स्थान वर्णों की संख्या और प्रकार का किसी भी दिशा में मिलान करने की आवश्यकता नहीं है।
* व्हाइटस्पेस (कंप्यूटर विज्ञान): कोई भी व्हाइटस्पेस वर्ण शून्य या अधिक व्हाइटस्पेस (कंप्यूटर विज्ञान) वर्णों के लिए स्कैन ट्रिगर करता है। रिक्त स्थान वर्णों की संख्या और प्रकार का किसी भी दिशा में मिलान करने की आवश्यकता नहीं है।
Line 91: Line 88:


अनेक फ़्लोट प्रकार के वर्णों के मामले में {{tt|a, e, f, g}}, कई कार्यान्वयन अधिकांश को एक ही पार्सर में संक्षिप्त करना चुनते हैं। Microsoft MSVCRT इसके साथ करता है {{tt|e, f, g}},<ref>{{cite web |title=स्कैनफ़ प्रकार फ़ील्ड वर्ण|url=https://docs.microsoft.com/en-us/cpp/c-runtime-library/scanf-type-field-characters?view=vs-2019 |website=docs.microsoft.com }}</ref> जबकि [[glibc]] चारों के साथ ऐसा करता है।<ref name=linux>{{man|3|scanf|Linux}}</ref>
अनेक फ़्लोट प्रकार के वर्णों के मामले में {{tt|a, e, f, g}}, कई कार्यान्वयन अधिकांश को एक ही पार्सर में संक्षिप्त करना चुनते हैं। Microsoft MSVCRT इसके साथ करता है {{tt|e, f, g}},<ref>{{cite web |title=स्कैनफ़ प्रकार फ़ील्ड वर्ण|url=https://docs.microsoft.com/en-us/cpp/c-runtime-library/scanf-type-field-characters?view=vs-2019 |website=docs.microsoft.com }}</ref> जबकि [[glibc]] चारों के साथ ऐसा करता है।<ref name=linux>{{man|3|scanf|Linux}}</ref>


== कमजोरियाँ ==
== कमजोरियाँ ==

Revision as of 17:37, 3 August 2023

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

स्कैनएफ शब्द सी मानक लाइब्रेरी से आया है, जिसने इस प्रकार के फ़ंक्शन को लोकप्रिय बनाया, लेकिन ऐसे फ़ंक्शन सी से पहले के हैं, और अन्य नामों का उपयोग किया जाता है, जैसे readf ALGOL 68 में। स्कैनफ प्रारूप स्ट्रिंग्स, जो स्वरूपित इनपुट (पदच्छेद ) प्रदान करते हैं, प्रिंटफ प्रारूप स्ट्रिंग्स के पूरक हैं, जो स्वरूपित आउटपुट (टेम्पलेटिंग भाषा) प्रदान करते हैं। ये अधिक परिष्कृत और लचीले पार्सर या टेम्पलेट इंजन की तुलना में सरल कार्यक्षमता और निश्चित प्रारूप प्रदान करते हैं, लेकिन कई उद्देश्यों के लिए पर्याप्त हैं।

इतिहास

माइक लेस्क की stdio.h|पोर्टेबल इनपुट/आउटपुट लाइब्रेरी, सहित scanf, संस्करण 7 यूनिक्स में आधिकारिक तौर पर यूनिक्स का हिस्सा बन गया।[1]


==उपयोग== scanf ई> फ़ंक्शन, जो सी प्रोग्रामिंग भाषा में पाया जाता है, मानक इनपुट (अक्सर एक कमांड लाइन इंटरफेस या समान प्रकार का टेक्स्ट यूजर इंटरफ़ेस) से संख्याओं और अन्य डेटा प्रकार के लिए इनपुट पढ़ता है।

निम्नलिखित सी कोड मानक इनपुट स्ट्रीम से अस्वरूपित दशमलव पूर्णांकों की एक चर संख्या को पढ़ता है और उनमें से प्रत्येक को अलग-अलग पंक्तियों में प्रिंट करता है:

#include <stdio.h>

int main(void)
{
    int n;

    while (scanf("%d", &n) == 1)
        printf("%d\n", n);
    return 0;
}

उपरोक्त प्रोग्राम द्वारा संसाधित होने के बाद, पूर्णांकों की एक अनियमित स्थान वाली सूची जैसे

456 123 789 456 12
456 1
   2378

लगातार अंतराल पर इस प्रकार दिखाई देगा:

456
123
789
456
12
456
1
2378

किसी शब्द का प्रिंट आउट लेने के लिए:

#include <stdio.h>

int main(void)
{
    char word[20];

    if (scanf("%19s", word) == 1)
        puts(word);
    return 0;
}

इससे कोई फर्क नहीं पड़ता कि प्रोग्रामर किस डेटा प्रकार को पढ़ना चाहता है, तर्क (जैसे &n ऊपर) मेमोरी की ओर इंगित करने वाला सूचक (कंप्यूटर प्रोग्रामिंग) होना चाहिए। अन्यथा, फ़ंक्शन सही ढंग से प्रदर्शन नहीं करेगा क्योंकि यह उस वेरिएबल के मेमोरी स्थान को इंगित करने के बजाय मेमोरी के गलत अनुभागों को ओवरराइट करने का प्रयास करेगा जिसके लिए आप इनपुट प्राप्त करने का प्रयास कर रहे हैं।

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

जैसा scanf केवल मानक इनपुट से पढ़ने के लिए निर्दिष्ट किया गया है, इंटरफ़ेस (कंप्यूटर विज्ञान) वाली कई प्रोग्रामिंग भाषाओं, जैसे PHP, में डेरिवेटिव होते हैं जैसे sscanf और fscanf लेकिन नहीं scanf अपने आप।

प्रारूप स्ट्रिंग विनिर्देश

फ़ॉर्मेटिंग प्लेसहोल्डर (कंप्यूटिंग) अंदर है scanf कमोबेश प्रिंटफ| के समान ही हैंprintf, इसका उल्टा कार्य। प्रिंटफ की तरह, POSIX एक्सटेंशन n$ परिभाषित किया गया।[2]

प्रारूप स्ट्रिंग में शायद ही कभी स्थिरांक होते हैं (यानी, वर्ण जो प्लेसहोल्डर (कंप्यूटिंग) को स्वरूपित नहीं कर रहे हैं), मुख्यतः क्योंकि एक प्रोग्राम आमतौर पर ज्ञात डेटा को पढ़ने के लिए डिज़ाइन नहीं किया गया है, हालांकि scanf यदि स्पष्ट रूप से निर्दिष्ट किया गया है तो इन्हें स्वीकार करता है। अपवाद एक या अधिक व्हाइटस्पेस (कंप्यूटर विज्ञान) वर्ण है, जो इनपुट में सभी व्हाइटस्पेस वर्णों को हटा देता है।[2]

सबसे अधिक उपयोग किए जाने वाले कुछ प्लेसहोल्डर इस प्रकार हैं:

  • %a : एक फ़्लोटिंग-पॉइंट नंबर को उसके हेक्साडेसिमल नोटेशन में स्कैन करें।
  • %d : एक पूर्णांक को हस्ताक्षरित दशमलव संख्या के रूप में स्कैन करें।
  • %i : एक पूर्णांक को हस्ताक्षरित संख्या के रूप में स्कैन करें। के समान %d, लेकिन पहले आने पर संख्या को हेक्साडेसिमल के रूप में व्याख्या करता है 0x और अष्टक जब से पहले 0. उदाहरण के लिए, स्ट्रिंग 031 का उपयोग करके 31 के रूप में पढ़ा जाएगा %d, और 25 का उपयोग कर रहे हैं %i. झंडा h में %hi ए में रूपांतरण को इंगित करता है short और hh ए में रूपांतरण char.
  • %u : दशमलव के लिए स्कैन करें unsigned int (ध्यान दें कि C99 मानक में इनपुट मान ऋण चिह्न वैकल्पिक है, इसलिए यदि ऋण चिह्न पढ़ा जाता है, तो कोई त्रुटि उत्पन्न नहीं होगी और परिणाम एक ऋणात्मक संख्या का पूरक होगा, संभवतः एक बहुत बड़ा मान। देखें strtoul().[failed verification]) तदनुसार, %hu एक के लिए स्कैन करता है unsigned short और %hhu एक के लिए unsigned char.
  • %f : एक तैरनेवाला स्थल नंबर को सामान्य (फ़िक्स्ड-पॉइंट अंकगणित|फ़िक्स्ड-पॉइंट) नोटेशन में स्कैन करें।
  • %g, %G : किसी फ़्लोटिंग-पॉइंट संख्या को सामान्य या घातांकीय नोटेशन में स्कैन करें। %g छोटे अक्षरों का उपयोग करता है और %G अपरकेस का उपयोग करता है.
  • %x, %X : एक पूर्णांक को अहस्ताक्षरित हेक्साडेसिमल संख्या के रूप में स्कैन करें।
  • %o : एक पूर्णांक को अष्टक संख्या के रूप में स्कैन करें।
  • %s : एक वर्ण स्ट्रिंग को स्कैन करें. स्कैन व्हाइटस्पेस (कंप्यूटर विज्ञान) पर समाप्त होता है। स्ट्रिंग के अंत में एक शून्य वर्ण संग्रहीत होता है, जिसका अर्थ है कि आपूर्ति किया गया बफ़र निर्दिष्ट इनपुट लंबाई से कम से कम एक वर्ण लंबा होना चाहिए।
  • %c : एक अक्षर (चार) को स्कैन करें। कोई शून्य वर्ण नहीं जोड़ा गया है.
  • व्हाइटस्पेस (कंप्यूटर विज्ञान): कोई भी व्हाइटस्पेस वर्ण शून्य या अधिक व्हाइटस्पेस (कंप्यूटर विज्ञान) वर्णों के लिए स्कैन ट्रिगर करता है। रिक्त स्थान वर्णों की संख्या और प्रकार का किसी भी दिशा में मिलान करने की आवश्यकता नहीं है।
  • %lf दोहरा परिशुद्धता फ़्लोटिंग-पॉइंट प्रारूप प्रारूप फ़्लोटिंग-पॉइंट नंबर के रूप में स्कैन करें। लंबे विनिर्देशक के साथ फ़्लोट प्रारूप।
  • %Lf : एक लंबे डबल फ़्लोटिंग-पॉइंट नंबर के रूप में स्कैन करें। लंबे लंबे विनिर्देशक को फ़्लोट करें।
  • %n : कुछ भी अपेक्षित नहीं है. इनपुट से अब तक उपभोग किए गए वर्णों की संख्या अगले पॉइंटर के माध्यम से संग्रहीत की जाती है, जो कि int का पॉइंटर होना चाहिए। यह रूपांतरण नहीं है और फ़ंक्शन द्वारा लौटाई गई संख्या में वृद्धि नहीं करता है।


उपरोक्त का उपयोग संख्यात्मक संशोधक और के साथ संयोजन में किया जा सकता है l, L संशोधक जो प्रतिशत चिह्न और अक्षर के बीच में लंबे समय तक खड़े रहते हैं। प्रतिशत चिह्न और उससे पहले के अक्षरों के बीच संख्यात्मक मान भी हो सकते हैं long संशोधक यदि कोई हो, जो स्कैन किए जाने वाले वर्णों की संख्या निर्दिष्ट करता है। एक वैकल्पिक तारांकन (*) प्रतिशत प्रतीक के ठीक बाद यह दर्शाता है कि इस प्रारूप विनिर्देशक द्वारा पढ़ा गया डेटाम एक चर में संग्रहीत नहीं किया जाना है। इस गिराए गए चर के लिए प्रारूप स्ट्रिंग के पीछे कोई तर्क शामिल नहीं किया जाना चाहिए। ff ई>प्रिंटफ में संशोधक स्कैनएफ में मौजूद नहीं है, जिससे इनपुट और आउटपुट के मोड के बीच अंतर पैदा होता है। ll ई> और hh संशोधक C90 मानक में मौजूद नहीं हैं, लेकिन C99 मानक में मौजूद हैं।[3] प्रारूप स्ट्रिंग का एक उदाहरण है

"%7d%s %c%lf"

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

अनेक फ़्लोट प्रकार के वर्णों के मामले में a, e, f, g, कई कार्यान्वयन अधिकांश को एक ही पार्सर में संक्षिप्त करना चुनते हैं। Microsoft MSVCRT इसके साथ करता है e, f, g,[4] जबकि glibc चारों के साथ ऐसा करता है।[2]

कमजोरियाँ

scanf स्ट्रिंग हमलों को प्रारूपित करने के प्रति संवेदनशील है। यह सुनिश्चित करने के लिए बहुत सावधानी बरतनी चाहिए कि प्रारूप स्ट्रिंग आक्रमण स्ट्रिंग और सरणी आकार की सीमाएं शामिल हैं। अधिकांश मामलों में उपयोगकर्ता से इनपुट स्ट्रिंग का आकार मनमाना होता है और इसे पहले निर्धारित नहीं किया जा सकता है scanf फ़ंक्शन निष्पादित किया गया है. इस का मतलब है कि %s लंबाई विनिर्देशक के बिना प्लेसहोल्डर स्वाभाविक रूप से असुरक्षित हैं और बफ़र ओवरफ़्लो के लिए शोषण योग्य हैं। एक अन्य संभावित समस्या डायनामिक फ़ॉर्मेटिंग स्ट्रिंग्स को अनुमति देना है, उदाहरण के लिए कॉन्फ़िगरेशन फ़ाइलों या अन्य उपयोगकर्ता-नियंत्रित फ़ाइलों में संग्रहीत फ़ॉर्मेटिंग स्ट्रिंग्स। इस मामले में स्ट्रिंग आकार की अनुमत इनपुट लंबाई तब तक निर्दिष्ट नहीं की जा सकती जब तक कि फ़ॉर्मेटिंग स्ट्रिंग की पहले से जाँच नहीं की जाती और सीमाएँ लागू नहीं की जातीं। इससे संबंधित अतिरिक्त या बेमेल फ़ॉर्मेटिंग प्लेसहोल्डर हैं जो वास्तविक Varargs.h सूची से मेल नहीं खाते हैं। Varargs.hs के विशेष कार्यान्वयन के आधार पर, इन प्लेसहोल्डर्स को आंशिक रूप से स्टैक से निकाला जा सकता है या इसमें अवांछनीय या यहां तक ​​कि असुरक्षित पॉइंटर्स भी हो सकते हैं।

यह भी देखें

  • सी प्रोग्रामिंग भाषा
  • स्ट्रिंग आक्रमण को प्रारूपित करें
  • प्रिंटफ़ प्रारूप स्ट्रिंग
  • स्ट्रिंग प्रक्षेप

संदर्भ

  1. McIlroy, M. D. (1987). A Research Unix reader: annotated excerpts from the Programmer's Manual, 1971–1986 (PDF) (Technical report). CSTR. Bell Labs. 139.
  2. 2.0 2.1 2.2 scanf(3) – Linux Programmer's Manual – Library Functions
  3. C99 standard, §7.19.6.2 "The fscanf function" alinea 11.
  4. "स्कैनफ़ प्रकार फ़ील्ड वर्ण". docs.microsoft.com.


बाहरी संबंध