आरक्षित शब्द

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

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

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

भेद
एक भाषा में आरक्षित शब्दों और खोजशब्दों के समूह प्रायः मेल खाते हैं या लगभग बराबर होते हैं, और भेद सूक्ष्म होता है, इसलिए शब्दों को प्रायः एक दूसरे के स्थान पर उपयोग किया जाता है। हालांकि, सावधानीपूर्वक उपयोग में वे प्रतिष्ठित हैं।

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

इसके विपरीत, खोजशब्दों को आरक्षित शब्द नहीं होना चाहिए, उनकी भूमिका संदर्भ से समझी जाती है, या उन्हें दूसरे तरीके से अलग किया जा सकता है, जैसे कि स्ट्रैपिंग (प्रोग्रामिंग)। उदाहरण के लिए, मुहावरा  अधिकांश व्याकरणों में असंदिग्ध है, क्योंकि if क्लॉज का कंट्रोल स्टेटमेंट a से शुरू नहीं हो सकता है , और इस प्रकार फोरट्रान जैसी कुछ भाषाओं में इसकी स्वीकृति है। वैकल्पिक रूप से, एल्गोरिथम भाषा 68 में, खोजशब्दों को बोल्ड में सूचीबद्ध करके कठोर भाषा में - किसी तरह से अलग करने के लिए चिह्नित किया जाना चाहिए, और इस प्रकार आरक्षित शब्द नहीं हैं। इस प्रकार सख्त भाषा में निम्नलिखित व्यंजक कानूनी है, बोल्ड कीवर्ड के रूप में सामान्य पहचानकर्ता के साथ संघर्ष नहीं करता है  :
 * यदि eq 0 तो 1 fi

हालाँकि, एल्गोरिथम भाषा 68 में एक स्ट्रॉपिंग शासन भी है जिसमें कीवर्ड आरक्षित शब्द हैं, इसका एक उदाहरण है कि ये विशिष्ट अवधारणाएँ प्रायः कैसे मेल खाती हैं; इसका पालन कई आधुनिक भाषाओं में किया जाता है।

सिंटेक्स
एक आरक्षित शब्द वह है जो एक सामान्य शब्द की तरह दिखता है, लेकिन एक सामान्य शब्द के रूप में प्रयोग करने की स्वीकृति नहीं है। औपचारिक रूप से इसका मतलब यह है कि यह पहचानकर्ताओं के सामान्य शाब्दिक वाक्य-विन्यास (शब्दों का वाक्य-विन्यास) को संतुष्ट करता है - उदाहरण के लिए, अक्षरों का एक क्रम होना - लेकिन इसका उपयोग नहीं किया जा सकता है जहाँ पहचानकर्ताओं का उपयोग किया जाता है। उदाहरण के लिए शब्द  सामान्य रूप से एक आरक्षित शब्द है, जबकि   सामान्य रूप से ऐसा नहीं है   एक वैध असाइनमेंट है, लेकिन   क्या नहीं है।

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

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

इस स्थिति में आरक्षित शब्दों को शाब्दिक व्याकरण के भाग के रूप में परिभाषित किया गया है, और प्रत्येक पहचानकर्ता से अलग एक अलग प्रकार के रूप में चिन्हित किया गया है। पारंपरिक संकेतन में, आरक्षित शब्द  और   उदाहरण के लिए प्रकार के रूप में टोकन हैं   और , क्रमशः, जबकि   और   दोनों प्रकार के रूप में टोकन हैं.

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

आरक्षित श्रेणियां
शब्दों की विशिष्ट सूचियों को आरक्षित करने के अतिरिक्त, कुछ भाषाएँ भविष्य के भाषा संस्करण, विभिन्न बोलियों, संकलक विक्रेता-विशिष्ट एक्सटेंशन के लिए निजी स्थान के रूप में उपयोग करने के लिए या एक संकलक द्वारा आंतरिक उपयोग के लिए, विशेष रूप से नाम प्रबंधन में, शब्दों की पूरी श्रृंखला आरक्षित करती हैं।

यह प्रायः एक उपसर्ग, प्रायः एक या अधिक बल देना का उपयोग करके किया जाता है। C और C++ इस संबंध में उल्लेखनीय हैं: C99 आरक्षित पहचानकर्ता जो दो अंडरस्कोर या एक अंडरस्कोर के साथ शुरू होता है, जिसके बाद एक अपरकेस अक्षर होता है, और आगे ऐसे पहचानकर्ता आरक्षित होते हैं जो फ़ाइल दायरे में उपयोग के लिए एकल अंडरस्कोर (साधारण और टैग रिक्त स्थान में) से शुरू होते हैं; सी ++ 03 के साथ उन पहचानकर्ताओं को सुरक्षित रखता है जिनमें कहीं भी डबल अंडरस्कोर होता है - यह एक विभाजक (उपयोगकर्ता पहचानकर्ताओं को जोड़ने के लिए) के रूप में एक डबल अंडरस्कोर के उपयोग की स्वीकृति देता है, उदाहरण के लिए।

पायथन में आंतरिक पहचानकर्ताओं में दोहरे अंडरस्कोर के लगातार उपयोग ने संक्षिप्त नाम डंडर को जन्म दिया; यह मार्क जैक्सन द्वारा गढ़ा गया था और स्वतंत्र रूप से टिम होचबर्ग द्वारा, 2002 में एक ही प्रश्न के उत्तर में दोनों एक दूसरे के मिनटों के भीतर।

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

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

एक उल्लेखनीय उदाहरण जावा (प्रोग्रामिंग भाषा) में है, जहां  और   आरक्षित शब्द हैं - उनका जावा में कोई अर्थ नहीं है लेकिन उन्हें पहचानकर्ता के रूप में भी उपयोग नहीं किया जा सकता है। शर्तों को आरक्षित करके, पुराने जावा स्रोत कोड को तोड़े बिना, यदि वांछित हो, तो उन्हें जावा के भविष्य के संस्करणों में लागू किया जा सकता है। उदाहरण के लिए, 1999 में C++- जैसे जोड़ने का प्रस्ताव था   भाषा के लिए, जिसका उपयोग करना संभव था   शब्द, चूंकि यह आरक्षित था लेकिन वर्तमान में अप्रयुक्त है; हालाँकि, इस प्रस्ताव को अस्वीकार कर दिया गया था - विशेष रूप से क्योंकि तथापि फीवेरिएबल को जोड़ने से कोई सम्मिलित प्रोग्राम नहीं टूटेगा, इसे मानक लाइब्रेरी (विशेष रूप से संग्रह में) का उपयोग करने से संगतता टूट जाएगी। जावास्क्रिप्ट में विशेष फंक्शनक्षमता के बिना कई आरक्षित शब्द भी होते हैं; परिशुद्ध सूची संस्करण और मोड से भिन्न होती है। भाषाएँ इस बात में महत्वपूर्ण रूप से भिन्न होती हैं कि वे कितनी बार नए आरक्षित शब्दों या खोजशब्दों का परिचय देती हैं और वे उन्हें कैसे नाम देती हैं, कुछ भाषाएँ बहुत रूढ़िवादी हैं और नए खोजशब्दों को संभवयतः ही कभी प्रस्तुत करती हैं या कभी नहीं, सम्मिलित प्रोग्रामों को तोड़ने से बचने के लिए, जबकि अन्य भाषाएँ नए खोजशब्दों को अधिक स्वतंत्र रूप से प्रस्तुत करती हैं, सम्मिलित की आवश्यकता होती है विरोध करने वाले सम्मिलित पहचानकर्ताओं को बदलने के लिए प्रोग्राम। C++11 की तुलना में C11 (C मानक संशोधन) में नए कीवर्ड द्वारा एक केस स्टडी दी गई है, दोनों 2011 से - याद रखें कि C और C++ में, पहचानकर्ता जो एक अंडरस्कोर के साथ शुरू होते हैं, उसके बाद अपरकेस अक्षर आरक्षित होते हैं: "C कमेटी यूजर नेम स्पेस में नए कीवर्ड्स नहीं बनाना चयन करती है, क्योंकि सामान्य रूप से यह उपेक्षा की जाती है कि C का प्रत्येक संशोधन पुराने C प्रोग्रामों को खोजने से बच जाएगा। तुलनात्मक रूप से, C++ समिति (WG21) नए खोजशब्दों को पुराने खोजशब्दों की तरह सामान्य-दिखने के लिए प्राथमिकता देती है। उदाहरण के लिए, सी ++ 11 एक थ्रेड के लिए स्थिर भंडारण स्थानीय को नामित करने के लिए एक नया कीवर्ड परिभाषित करता है। C11 नए कीवर्ड को   के रूप में परिभाषित करता है। नए C11 हैडर &lt;threads.h&gt;, सामान्य-दिखने वाले नाम प्रदान करने के लिए एक मैक्रो परिभाषा है:

यानी C11 ने कीवर्ड प्रस्तुत किया  आरक्षित शब्दों के एक सम्मिलित सेट के भीतर (एक निश्चित उपसर्ग वाले), और फिर इसके उपयोग की स्वीकृति देने के लिए एक अलग सुविधा (मैक्रो प्रोसेसिंग) का उपयोग किया जैसे कि यह बिना किसी उपसर्ग के एक नया कीवर्ड था, जबकि C++11 कीवर्ड का परिचय देता है   इसके होने पर भी यह एक सम्मिलित आरक्षित शब्द नहीं है, इसका उपयोग करने वाले किसी भी प्रोग्राम को तोड़ना, लेकिन मैक्रो प्रोसेसिंग की आवश्यकता के बिना।

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

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

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

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

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

कुछ भाषाएँ, जैसे कि परिशिष्ट भाग, इस दृष्टिकोण में अत्यंत उदार हैं, जिससे विशिष्ट उद्देश्यों के लिए मुख्य खोजशब्दों को फिर से परिभाषित किया जा सकता है।

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

सामान्य रूप से, जब कोई प्रोग्रामर वेरिएबल या फ़ंक्शन नाम के लिए कीवर्ड का उपयोग करने का प्रयास करता है, तो संकलन त्रुटि ट्रिगर हो जाएगी। अधिकांश आधुनिक संपादकों में, प्रोग्रामर को याद दिलाने या सूचित करने के लिए कि वे कीवर्ड हैं, कीवर्ड स्वचालित रूप से एक विशेष टेक्स्ट रंग के लिए सेट होते हैं।

मैक्रो (कंप्यूटर विज्ञान) या आलसी मूल्यांकन वाली भाषाओं में, नियंत्रण प्रवाह निर्माण जैसे  मैक्रोज़ या फ़ंक्शंस के रूप में फंक्शनान्वित किया जा सकता है। इन अभिव्यंजक सुविधाओं के बिना भाषाओं में, वे सामान्य रूप से खोजशब्द होते हैं।

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

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

क्योंकि आरक्षित शब्दों को पहचानकर्ता के रूप में उपयोग नहीं किया जा सकता है, उपयोगकर्ता जानबूझकर आरक्षित शब्दों की गलत वर्तनी को पहचानकर्ता के रूप में चुन सकते हैं, जैसे कि clazz प्रकार के जावा वेरिएबल के लिए Class.

आरक्षित शब्द और भाषा स्वतंत्रता
माइक्रोसॉफ्ट का .NET फ्रेमवर्क|.नेट सामान्य भाषा अवसंरचना| कॉमन लैंग्वेज इन्फ्रास्ट्रक्वेरिएबल (CLI) विनिर्देश 40+ विभिन्न प्रोग्रामिंग भाषाओं में लिखे गए कोड को अंतिम उत्पाद में संयोजित करने की स्वीकृति देता है। इस वजह से, पहचानकर्ता/आरक्षित शब्द टकराव तब हो सकता है जब एक भाषा में फंक्शनान्वित कोड किसी अन्य भाषा में लिखे गए कोड को निष्पादित करने का प्रयास करता है। उदाहरण के लिए, एक Visual Basic .NET|Visual Basic.NET लाइब्रेरी में क्लास (कंप्यूटर विज्ञान) की परिभाषा हो सकती है जैसे: ' Class Definition of This in Visual Basic.NET: Public Class this ' This class does something... End Class

यदि यह एक टूलबॉक्स के हिस्से के रूप में संकलित और वितरित किया जाता है, तो एक सी शार्प (प्रोग्रामिंग भाषा) | सी # प्रोग्रामर, प्रकार के एक वेरिएबल को परिभाषित करने की इच्छा रखते हैं। "एक समस्या का सामना करना पड़ेगा:  सी # में एक आरक्षित शब्द है। इस प्रकार, निम्नलिखित सी # में संकलित नहीं होंगे: // Using This Class in C#: this x = new this;  // Won't compile! सदस्यों तक पहुँचने, आभासी तरीकों को ओवरराइड करने और नामस्थानों की पहचान करने पर एक समान समस्या उत्पन्न होती है।

यह स्ट्रॉपिंग (वाक्यविन्यास) द्वारा हल किया जाता है। इस समस्या के आसपास काम करने के लिए, विनिर्देश प्रोग्रामर को (सी # में) पहचानकर्ता से पहले संकेत पर करने की स्वीकृति देता है जो इसे संकलक द्वारा आरक्षित शब्द के अतिरिक्त पहचानकर्ता माना जाता है: // Using This Class in C#: @this x = new @this; // Will compile! स्थिरता के लिए, गैर-सार्वजनिक सेटिंग्स जैसे स्थानीय वेरिएबल, पैरामीटर नाम और निजी सदस्यों में भी इस उपयोग की स्वीकृति है।

यह भी देखें

 * सी सिंटैक्स # आरक्षित कीवर्ड
 * जावा कीवर्ड्स की सूची
 * प्रतीक (प्रोग्रामिंग)