कंप्यूटर प्रोग्रामिंग - वर्ण

यदि कंप्यूटर प्रोग्रामिंग में संख्याओं के साथ काम करना आसान था, तो पात्रों के साथ काम करना और भी आसान हो जाएगा। वर्ण एक, बी, सी, डी ...., ए, बी, सी, डी, ..... जैसे सरल अक्षर हैं, लेकिन एक अपवाद के साथ। कंप्यूटर प्रोग्रामिंग में किसी भी एक अंक की संख्या जैसे 0, 1, 2, .... और विशेष वर्ण जैसे $,%, +, -हर आदि को भी अक्षर के रूप में माना जाता है और उन्हें चरित्र प्रकार में निर्दिष्ट करना है। चर, आपको बस उन्हें अंदर डालने की जरूरत हैsingle quotes। उदाहरण के लिए, निम्न कथन एक वर्ण प्रकार चर को परिभाषित करता हैch और हम इसे 'a' मान देते हैं -

char ch = 'a';

यहाँ, ch चरित्र प्रकार का एक चर है जो कार्यान्वयन के चरित्र सेट के एक चरित्र को पकड़ सकता है और 'a' कहा जाता है a character literalया एक चरित्र स्थिर। न केवल a, b, c, .... बल्कि जब कोई भी संख्या जैसे 1, 2, 3 .... या कोई विशेष वर्ण जैसे !, @, #, #, #, $, .... को एकल उद्धरण के अंदर रखा जाता है। , तो वे एक चरित्र शाब्दिक के रूप में माना जाएगा और चरित्र प्रकार के एक चर को सौंपा जा सकता है, इसलिए निम्नलिखित एक मान्य कथन है -

char ch = '1';

एक वर्ण डेटा प्रकार 8 बिट मेमोरी का उपभोग करता है जिसका अर्थ है कि आप किसी भी पात्र में कुछ भी संग्रहीत कर सकते हैं जिसका ASCII मूल्य -127 से 127 के बीच है, इसलिए यह 256 विभिन्न मूल्यों में से किसी को भी पकड़ सकता है। एक चरित्र डेटा प्रकार आपके कीबोर्ड पर उपलब्ध किसी भी वर्ण को संग्रहीत कर सकता है, जिसमें विशेष वर्ण शामिल हैं !, @, #, #, $,%, ^, &, *, (,), _, +, {,},}, आदि।

ध्यान दें कि आप एकल उद्धरणों के अंदर केवल एक वर्णमाला या एकल अंक संख्या रख सकते हैं और एक से अधिक वर्णमाला या अंकों को एकल उद्धरण के अंदर अनुमति नहीं है। इसलिए C प्रोग्रामिंग में निम्नलिखित कथन अमान्य हैं -

char ch1 = 'ab';
char ch2 = '10';

नीचे दिया गया एक सरल उदाहरण है, जो दिखाता है कि C प्रोग्रामिंग लैंग्वेज में अक्षरों को कैसे परिभाषित, असाइन और प्रिंट किया जाए -

#include <stdio.h>

int main() {
   char  ch1;
   char  ch2;
   char  ch3;
   char  ch4;
   
   ch1 = 'a';      
   ch2 = '1';
   ch3 = '$';
   ch4 = '+';  

   printf( "ch1: %c\n", ch1);
   printf( "ch2: %c\n", ch2);
   printf( "ch3: %c\n", ch3);
   printf( "ch4: %c\n", ch4);
}

यहाँ, हमने% c का उपयोग चरित्र डेटा प्रकार को प्रिंट करने के लिए किया। जब उपरोक्त कार्यक्रम निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

ch1: a
ch2: 1
ch3: $
ch4: +

बच अनुक्रम

कई प्रोग्रामिंग भाषाएं नामक एक अवधारणा का समर्थन करती हैं Escape Sequence। जब एक चरित्र बैकस्लैश (\) से पहले होता है, तो इसे एक एस्केप सीक्वेंस कहा जाता है और यह कंपाइलर के लिए एक विशेष अर्थ रखता है। उदाहरण के लिए, निम्नलिखित कथन में \ n एक मान्य वर्ण है और इसे एक नई पंक्ति वर्ण कहा जाता है -

char ch = '\n';

यहाँ, चरित्र nबैकस्लैश (\) से पहले लिया गया है, इसका विशेष अर्थ है जो एक नई पंक्ति है लेकिन ध्यान रखें कि बैकस्लैश (\) का केवल कुछ वर्णों के साथ विशेष अर्थ है। निम्नलिखित कथन सी प्रोग्रामिंग में कोई अर्थ नहीं बताएगा और इसे एक अमान्य कथन माना जाएगा -

char ch = '\1';

निम्नलिखित तालिका सी प्रोग्रामिंग भाषा में उपलब्ध एस्केप अनुक्रमों को सूचीबद्ध करती है -

निकास का क्रम विवरण
\ t इस बिंदु पर पाठ में एक टैब सम्मिलित करता है।
\ b इस बिंदु पर पाठ में एक बैकस्पेस सम्मिलित करता है।
\ n इस बिंदु पर पाठ में एक नई रेखा सम्मिलित करता है।
\ r इस बिंदु पर पाठ में एक गाड़ी लौटाता है।
\ च इस बिंदु पर पाठ में एक फार्म फ़ीड सम्मिलित करता है।
\ ' इस बिंदु पर पाठ में एक एकल उद्धरण चरित्र सम्मिलित करता है।
\ " इस बिंदु पर पाठ में एक दोहरे उद्धरण वर्ण सम्मिलित करता है।
\\ इस बिंदु पर पाठ में एक बैकस्लैश वर्ण सम्मिलित करता है।

निम्न उदाहरण दिखाता है कि संकलक प्रिंट स्टेटमेंट में एस्केप सीक्वेंस की व्याख्या कैसे करता है -

#include <stdio.h>

int main() {
   char  ch1;
   char  ch2;
   char  ch3;
   char  ch4;
   
   ch1 = '\t';      
   ch2 = '\n';

   printf( "Test for tabspace %c and a newline %c will start here", ch1, ch2);
}

जब उपरोक्त कार्यक्रम निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

Test for tabspace     and a newline 
will start here

जावा में वर्ण

निम्नलिखित जावा में लिखित समान कार्यक्रम है। Java कैरेक्टर डेटा टाइप को उसी तरह से हैंडल करता है जैसे हमने C प्रोग्रामिंग में देखा है। हालांकि, जावा चरित्र हेरफेर के लिए अतिरिक्त सहायता प्रदान करता है।

आप आउटपुट को देखने के लिए निम्न प्रोग्राम को निष्पादित करने का प्रयास कर सकते हैं, जो उपरोक्त सी उदाहरण द्वारा उत्पन्न परिणाम के समान होना चाहिए।

public class DemoJava {
   public static void main(String []args) {
      char  ch1;
      char  ch2;
      char  ch3;
      char  ch4;
   
      ch1 = 'a';      
      ch2 = '1';
      ch3 = '$';
      ch4 = '+';  

      System.out.format( "ch1: %c\n", ch1);
      System.out.format( "ch2: %c\n", ch2);
      System.out.format( "ch3: %c\n", ch3);
      System.out.format( "ch4: %c\n", ch4);
   }
}

जब उपरोक्त कार्यक्रम निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

ch1:  a
ch2:  1
ch3:  $
ch4:  +

जावा उसी तरह से भागने के क्रम का भी समर्थन करता है जिस तरह से आपने उन्हें C प्रोग्रामिंग में इस्तेमाल किया है।

अजगर में वर्ण

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

निम्नलिखित पायथन में लिखित समान कार्यक्रम है -

ch1 = 'a';      
ch2 = '1';
ch3 = '$';
ch4 = '+'; 

print "ch1: ", ch1
print "ch2: ", ch2
print "ch3: ", ch3
print "ch4: ", ch4

जब उपरोक्त कार्यक्रम निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

ch1:  a
ch2:  1
ch3:  $
ch4:  +

पाइथन उसी तरह से भागने के क्रम का समर्थन करता है जैसे आपने C प्रोग्रामिंग में उनका उपयोग किया है।