डी प्रोग्रामिंग - चर
एक चर कुछ भी नहीं है लेकिन एक भंडारण क्षेत्र को दिया गया नाम है जो हमारे कार्यक्रमों में हेरफेर कर सकता है। डी में प्रत्येक चर का एक विशिष्ट प्रकार है, जो चर की स्मृति के आकार और लेआउट को निर्धारित करता है; मूल्यों की सीमा जो उस मेमोरी में संग्रहीत की जा सकती है; और परिचालनों का सेट जो चर पर लागू किया जा सकता है।
एक चर का नाम अक्षरों, अंकों और अंडरस्कोर वर्ण से बना हो सकता है। यह या तो एक पत्र या एक अंडरस्कोर से शुरू होना चाहिए। ऊपरी और निचले अक्षर अलग हैं क्योंकि डी केस-संवेदी है। पिछले अध्याय में बताए गए मूल प्रकारों के आधार पर, निम्नलिखित मूल चर प्रकार होंगे -
अनु क्रमांक। | टाइप और विवरण |
---|---|
1 | char आमतौर पर एक एकल ओकटेट (एक बाइट)। यह एक पूर्णांक प्रकार है। |
2 | int मशीन के लिए पूर्णांक का सबसे प्राकृतिक आकार। |
3 | float एकल-सटीक फ़्लोटिंग पॉइंट मान। |
4 | double एक डबल-सटीक फ़्लोटिंग पॉइंट मान। |
5 | void प्रकार की अनुपस्थिति का प्रतिनिधित्व करता है। |
डी प्रोग्रामिंग भाषा कई अन्य प्रकारों जैसे कि एन्यूमरेशन, पॉइंटर, एरे, स्ट्रक्चर, यूनियन आदि को परिभाषित करने की अनुमति देती है, जिसे हम बाद के अध्यायों में शामिल करेंगे। इस अध्याय के लिए, हम केवल मूल चर प्रकारों का अध्ययन करते हैं।
डी में परिवर्तनीय परिभाषा
एक चर परिभाषा संकलक को बताती है कि चर के लिए कहां और कितनी जगह बनाई जाए। एक चर परिभाषा एक डेटा प्रकार को निर्दिष्ट करती है और इसमें उस प्रकार के एक या अधिक चर की सूची शामिल होती है -
type variable_list;
यहाँ, type एक वैध D डेटा प्रकार होना चाहिए जिसमें char, wchar, int, float, double, bool, या कोई उपयोगकर्ता-निर्धारित ऑब्जेक्ट आदि शामिल हों, और variable_listअल्पविराम द्वारा अलग किए गए एक या एक से अधिक पहचानकर्ता नाम शामिल हो सकते हैं। कुछ मान्य घोषणाएँ यहाँ दिखाई गई हैं -
int i, j, k;
char c, ch;
float f, salary;
double d;
रेखा int i, j, k;दोनों घोषित करता है और चर को परिभाषित करता है i, j और k; जो संकलक को निर्देश देता है कि i, j, और k का प्रकार int नाम के चर बनाएं।
चर को उनकी घोषणा में आरंभीकृत किया जा सकता है (प्रारंभिक मूल्य सौंपा गया है)। इनिशियलाइज़र में एक समरूप चिन्ह होता है, जिसके बाद एक स्थिर अभिव्यक्ति होती है -
type variable_name = value;
उदाहरण
extern int d = 3, f = 5; // declaration of d and f.
int d = 3, f = 5; // definition and initializing d and f.
byte z = 22; // definition and initializes z.
char x = 'x'; // the variable x has the value 'x'.
जब एक चर को डी में घोषित किया जाता है, तो यह हमेशा अपने 'डिफॉल्ट इनिशलाइज़र' पर सेट होता है, जिसे मैन्युअल रूप से एक्सेस किया जा सकता है T.init कहाँ पे T प्रकार है (पूर्व) int.init)। पूर्णांक प्रकारों के लिए डिफ़ॉल्ट आरंभीकरण 0 है, बूलियन झूठे के लिए, और फ़्लोटिंग-पॉइंट संख्या NaN के लिए।
डी में परिवर्तनीय घोषणा
एक चर घोषणा संकलक को आश्वासन देती है कि दिए गए प्रकार और नाम के साथ एक चर मौजूद है ताकि संकलक चर के बारे में पूर्ण विवरण की आवश्यकता के बिना आगे संकलन के लिए आगे बढ़े। एक चर घोषणा के संकलन के समय इसका अर्थ होता है, संकलक को कार्यक्रम के लिंकिंग के समय वास्तविक चर घोषणा की आवश्यकता होती है।
उदाहरण
निम्नलिखित उदाहरण का प्रयास करें, जहां कार्यक्रम की शुरुआत में चर घोषित किए गए हैं, लेकिन मुख्य कार्य के अंदर परिभाषित और आरंभिक हैं -
import std.stdio;
int a = 10, b = 10;
int c;
float f;
int main () {
writeln("Value of a is : ", a);
/* variable re definition: */
int a, b;
int c;
float f;
/* Initialization */
a = 30;
b = 40;
writeln("Value of a is : ", a);
c = a + b;
writeln("Value of c is : ", c);
f = 70.0/3.0;
writeln("Value of f is : ", f);
return 0;
}
जब उपरोक्त कोड संकलित और निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Value of a is : 10
Value of a is : 30
Value of c is : 70
Value of f is : 23.3333
डी में लवल्यूज और रिवल्यूज
D में दो प्रकार के भाव हैं -
lvalue - एक अभिव्यक्ति जो एक लवल्यू है, वह एक असाइनमेंट के बाएं-हाथ या दाईं ओर के रूप में दिखाई दे सकती है।
rvalue - एक अभिव्यक्ति जो एक लकीर है वह दाईं ओर दिखाई दे सकती है - लेकिन एक असाइनमेंट के बाईं ओर नहीं।
वेरिएबल्स अंतराल हैं और इसलिए एक असाइनमेंट के बाईं ओर दिखाई दे सकते हैं। न्यूमेरिकल शाब्दिक नियम हैं और इसलिए इन्हें असाइन नहीं किया जा सकता है और यह बाईं ओर नहीं दिखाई दे सकता है। निम्नलिखित कथन मान्य है -
int g = 20;
लेकिन निम्नलिखित एक वैध बयान नहीं है और एक संकलन-समय त्रुटि उत्पन्न करेगा -
10 = 20;