डी प्रोग्रामिंग - साहित्य

निरंतर मान जो प्रोग्राम में स्रोत कोड के एक भाग के रूप में टाइप किए जाते हैं, कहलाते हैं literals

साहित्य किसी भी मूल डेटा प्रकार के हो सकते हैं और उन्हें इंटेगर न्यूमर्स, फ्लोटिंग-पॉइंट न्यूमर्स, कैरेक्टर्स, स्ट्रिंग्स और बूलियन वैल्यूज में विभाजित किया जा सकता है।

फिर, शाब्दिक को नियमित चर के समान माना जाता है सिवाय इसके कि उनकी परिभाषा के बाद उनके मूल्यों को संशोधित नहीं किया जा सकता है।

पूर्णांक का साहित्य

पूर्णांक शाब्दिक निम्नलिखित प्रकार के हो सकते हैं -

  • Decimal पहले अंक के साथ सामान्य संख्या के पुन: उपयोग का उपयोग 0 नहीं हो सकता है क्योंकि यह अंक अष्टक प्रणाली को इंगित करने के लिए आरक्षित है। यह अपने आप में 0 को शामिल नहीं करता है: 0 शून्य है।

  • Octal संख्या के लिए उपसर्ग के रूप में 0 का उपयोग करता है।

  • Binary उपसर्ग के रूप में 0b या 0B का उपयोग करता है।

  • Hexadecimal उपसर्ग के रूप में 0x या 0X का उपयोग करता है।

एक पूर्णांक शाब्दिक में एक प्रत्यय भी हो सकता है जो क्रमशः अहस्ताक्षरित और लंबे समय के लिए यू और एल का संयोजन है। प्रत्यय अपरकेस या लोअरकेस हो सकता है और किसी भी क्रम में हो सकता है।

जब आप एक प्रत्यय का उपयोग नहीं करते हैं, तो संकलक मूल्य के परिमाण के आधार पर int, uint, long, और ulong के बीच चयन करता है।

यहाँ पूर्णांक शाब्दिक के कुछ उदाहरण हैं -

212         // Legal 
215u        // Legal 
0xFeeL      // Legal 
078         // Illegal: 8 is not an octal digit 
032UU       // Illegal: cannot repeat a suffix

निम्नलिखित विभिन्न प्रकार के पूर्णांक शाब्दिक अन्य उदाहरण हैं -

85         // decimal 
0213       // octal
0x4b       // hexadecimal 
30         // int 
30u        // unsigned int 
30l        // long 
30ul       // unsigned long 
0b001      // binary

फ्लोटिंग पॉइंट लिटरल

फ्लोटिंग पॉइंट शाब्दिक को दशमलव प्रणाली में 1.568 या हेक्साडेसिमल प्रणाली में 0x91 के रूप में निर्दिष्ट किया जा सकता है। आदि।

दशमलव प्रणाली में, एक घातांक को चरित्र ई या ई और उसके बाद एक संख्या जोड़कर दर्शाया जा सकता है। उदाहरण के लिए, 2.3e4 का अर्थ है "4 की शक्ति से 2.3 गुना 10"। एक "+" वर्ण प्रतिपादक के मान से पहले निर्दिष्ट किया जा सकता है, लेकिन इसका कोई प्रभाव नहीं है। उदाहरण के लिए 2.3e4 और 2.3e + 4 समान हैं।

घातांक के मान से पहले जोड़ा गया "-" वर्ण "10 की शक्ति से विभाजित" होने का अर्थ बदलता है। उदाहरण के लिए, 2.3e-2 का अर्थ है "2.3 को 10 की शक्ति से 2 से विभाजित"।

हेक्साडेसिमल प्रणाली में, मान 0x या 0X से शुरू होता है। प्रतिपादक ई या ई के बजाय पी या पी द्वारा निर्दिष्ट किया गया है। प्रतिपादक का अर्थ "10 की शक्ति" नहीं है, लेकिन "2 की शक्ति" है। उदाहरण के लिए, 0xabc.defP4 में P4 का अर्थ है "4 की शक्ति से 2 गुना अधिक"।

यहाँ फ़्लोटिंग पॉइंट शाब्दिक के कुछ उदाहरण दिए गए हैं -

3.14159       // Legal 
314159E-5L    // Legal 
510E          // Illegal: incomplete exponent 
210f          // Illegal: no decimal or exponent 
.e55          // Illegal: missing integer or fraction 
0xabc.defP4   // Legal Hexa decimal with exponent 
0xabc.defe4   // Legal Hexa decimal without exponent.

डिफ़ॉल्ट रूप से, फ्लोटिंग पॉइंट शाब्दिक का प्रकार डबल है। एफ और एफ का मतलब फ्लोट है, और एल स्पेसियर का मतलब वास्तविक है।

बूलियन साहित्य

दो बूलियन शाब्दिक हैं और वे मानक डी कीवर्ड का हिस्सा हैं -

  • का एक मूल्य true सच का प्रतिनिधित्व करना।

  • का एक मूल्य false असत्य का प्रतिनिधित्व करना।

आपको 1 के बराबर के मूल्य और 0 के बराबर झूठ के मूल्य पर विचार नहीं करना चाहिए।

चरित्र साहित्य

चरित्र के शब्द एकल उद्धरणों में संलग्न हैं।

एक चरित्र शाब्दिक एक सादा चरित्र हो सकता है (जैसे, 'x'), एक एस्केप सीक्वेंस (जैसे, '\ t'), ASCII वर्ण (जैसे, '\ x21'), यूनिकोड वर्ण (जैसे, '\ u011e') या नामित चरित्र के रूप में (जैसे '' © ',' \ ♥ ',' \ '')।

डी में कुछ पात्र होते हैं जब वे बैकस्लैश से पहले होते हैं तो उनका विशेष अर्थ होगा और उनका उपयोग न्यूलाइन (\ n) या टैब (\ t) की तरह करने के लिए किया जाता है। यहाँ, आपके पास कुछ ऐसे पलायन अनुक्रम कोड की सूची है -

निकास का क्रम अर्थ
\\ \ चरित्र
\ ' 'चरित्र
\ " “चरित्र
\? ? चरित्र
\ए चेतावनी या घंटी
\ b बैकस्पेस
\ च फ़ीड बनाएं
\ n नई पंक्ति
\ r कैरिज रिटर्न
\ t क्षैतिज टैब
\ v लंबवत टैब

निम्न उदाहरण कुछ बच अनुक्रम अनुक्रम दिखाता है -

import std.stdio;
  
int main(string[] args) { 
   writefln("Hello\tWorld%c\n",'\x21'); 
   writefln("Have a good day%c",'\x21'); 
   return 0; 
}

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

Hello   World!

Have a good day!

स्ट्रिंग लिटरल

स्ट्रिंग शाब्दिक दोहरे उद्धरण चिह्नों में संलग्न हैं। एक तार में वर्ण होते हैं जो वर्ण शाब्दिक के समान होते हैं: सादे वर्ण, बच के क्रम और सार्वभौमिक वर्ण।

आप स्ट्रिंग लिटरल्स का उपयोग करके एक लंबी लाइन को कई लाइनों में तोड़ सकते हैं और उन्हें व्हाट्सएप का उपयोग करके अलग कर सकते हैं।

यहाँ स्ट्रिंग शाब्दिकों के कुछ उदाहरण दिए गए हैं -

import std.stdio;

int main(string[] args) {
   writeln(q"MY_DELIMITER
      Hello World
      Have a good day
      MY_DELIMITER");

   writefln("Have a good day%c",'\x21'); 
   auto str = q{int value = 20; ++value;}; 
   writeln(str); 
}

उपरोक्त उदाहरण में, आप प्रत्येक पंक्ति वर्णों का प्रतिनिधित्व करने के लिए q "MY_DELIMITER MY_DELIMITER" का उपयोग कर सकते हैं। साथ ही, आप D {कथन का प्रतिनिधित्व करने के लिए q {} देख सकते हैं।