शून्य वर्ण

शून्य वर्ण (शून्य टर्मिनेटर भी) शून्य मान वाला एक नियंत्रण वर्ण है। यह बॉडॉट कोड और ITA2 कोड, ISO/IEC 646 (या ASCII), C0 और C1 कंट्रोल कोड, यूनिवर्सल कोडेड [[ अक्षरों का समूह ]] (या यूनिकोड), और EBCDIC द्वारा परिभाषित सहित कई कैरेक्टर सेट में मौजूद है। यह लगभग सभी मुख्यधारा की प्रोग्रामिंग भाषाओं में उपलब्ध है। इसे अक्सर NUL (या NULL) के रूप में संक्षिप्त किया जाता है, हालांकि कुछ संदर्भों में उस शब्द का उपयोग अशक्त सूचक के लिए किया जाता है)। 8-बिट कोड में, इसे अशक्त बाइट के रूप में जाना जाता है।

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

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

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

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

नल के लिए हेक्साडेसिमल संकेतन है. बेस 64 स्ट्रिंग को डीकोड करना  अशक्त चरित्र भी देता है।

प्रलेखन में, अशक्त वर्ण को कभी-कभी एकल-एम (टाइपोग्राफी)-चौड़ाई के प्रतीक के रूप में दर्शाया जाता है जिसमें NUL अक्षर होते हैं। यूनिकोड में इसके लिए एक वर्ण है:.

एनकोडिंग
सभी आधुनिक वर्ण सेटों में, शून्य वर्ण का कोड बिंदु मान शून्य होता है। अधिकांश एनकोडिंग में, इसे शून्य मान वाली एकल कोड इकाई में अनुवादित किया जाता है। उदाहरण के लिए, UTF-8 में यह एक शून्य बाइट है। हालाँकि, UTF-8#Modified UTF-8|Modified UTF-8 में नल वर्ण को दो बाइट्स के रूप में एन्कोड किया गया है: 0xC0, 0x80। यह बाइट को शून्य के मान के साथ अनुमति देता है, जो अब किसी भी वर्ण के लिए उपयोग नहीं किया जाता है, जिसे स्ट्रिंग टर्मिनेटर के रूप में उपयोग किया जाता है।

बाहरी संबंध

 * Null Byte Injection WASC Threat Classification Null Byte Attack section
 * Poison Null Byte Introduction Introduction to Null Byte Attack
 * Apple null byte injection QR code vulnerability