डी प्रोग्रामिंग - डेटा प्रकार
डी प्रोग्रामिंग भाषा में, डेटा प्रकार विभिन्न प्रकारों के चर या कार्यों की घोषणा के लिए उपयोग की जाने वाली एक व्यापक प्रणाली को संदर्भित करते हैं। एक चर का प्रकार यह निर्धारित करता है कि यह भंडारण में कितना स्थान रखता है और संग्रहीत बिट पैटर्न की व्याख्या कैसे की जाती है।
D के प्रकारों को निम्नानुसार वर्गीकृत किया जा सकता है -
अनु क्रमांक। | प्रकार और विवरण |
---|---|
1 | Basic Types वे अंकगणित प्रकार हैं और तीन प्रकार के होते हैं: (ए) पूर्णांक, (बी) फ्लोटिंग-पॉइंट, और (सी) चरित्र। |
2 | Enumerated types वे फिर से अंकगणित प्रकार हैं। वे चर को परिभाषित करने के लिए उपयोग किए जाते हैं जिन्हें केवल पूरे कार्यक्रम में कुछ असतत पूर्णांक मान निर्दिष्ट किए जा सकते हैं। |
3 | The type void प्रकार निर्दिष्ट शून्य इंगित करता है कि कोई मान उपलब्ध नहीं है। |
4 | Derived types वे (ए) पॉइंटर प्रकार, (बी) एरे प्रकार, (सी) संरचना प्रकार, (डी) यूनियन प्रकार, और (ई) फ़ंक्शन प्रकार शामिल हैं। |
सरणी प्रकार और संरचना प्रकार को सामूहिक रूप से समग्र प्रकार के रूप में संदर्भित किया जाता है। फ़ंक्शन का प्रकार फ़ंक्शन के रिटर्न मान के प्रकार को निर्दिष्ट करता है। हम निम्नलिखित अनुभाग में बुनियादी प्रकार देखेंगे, जबकि अन्य प्रकार आगामी अध्यायों में शामिल किए जाएंगे।
पूर्णांक प्रकार
निम्न तालिका उनके भंडारण आकार और मूल्य श्रेणियों के साथ सूची पूर्णांक प्रकार देती है -
प्रकार | भंडारण का आकार | मूल्य सीमा |
---|---|---|
bool | 1 बाइट | असत्य या सत्य |
बाइट | 1 बाइट | -128 से 127 |
ubyte | 1 बाइट | 0 से 255 रु |
पूर्णांक | 4 निवाले | -2,147,483,648 से 2,147,483,647 |
uint | 4 निवाले | 0 से 4,294,967,295 रु |
कम | 2 बाइट्स | -32,768 से 32,767 |
ushort | 2 बाइट्स | 0 से 65,535 रु |
लंबा | 8 बाइट्स | -9223372036854775808 से 9223372036854775807 |
Ulong | 8 बाइट्स | 0 से 18446744073709551615 |
किसी प्रकार या चर का सटीक आकार प्राप्त करने के लिए, आप निम्न का उपयोग कर सकते हैं sizeofऑपरेटर। अभिव्यक्ति प्रकार। (आकार) बाइट्स में ऑब्जेक्ट या प्रकार के भंडारण का आकार देता है। निम्नलिखित उदाहरण किसी भी मशीन पर int प्रकार का आकार प्राप्त करता है -
import std.stdio;
int main() {
writeln("Length in bytes: ", ulong.sizeof);
return 0;
}
जब आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Length in bytes: 8
फ्लोटिंग-पॉइंट प्रकार
निम्न तालिका में भंडारण आकार, मूल्य श्रेणियों और उनके उद्देश्य के साथ मानक फ्लोट-पॉइंट प्रकारों का उल्लेख है -
प्रकार | भंडारण का आकार | मूल्य सीमा | उद्देश्य |
---|---|---|---|
नाव | 4 निवाले | 1.17549e-38 से 3.40282e + 38 | 6 दशमलव स्थान |
दोहरा | 8 बाइट्स | 2.22507e-308 से 1.79769e + 308 | 15 दशमलव स्थान |
असली | 10 बाइट्स | 3.3621e-4932 से 1.18973e + 4932 | या तो सबसे बड़ा फ्लोटिंग पॉइंट प्रकार जो हार्डवेयर का समर्थन करता है, या डबल; जो भी बड़ा हो |
ifloat | 4 निवाले | 1.17549e-38i से 3.40282e + 38i | फ्लोट का काल्पनिक मूल्य प्रकार |
idouble | 8 बाइट्स | 2.22507e-308i से 1.79769e + 308i | डबल का काल्पनिक मूल्य प्रकार |
मैं असली | 10 बाइट्स | 3.3621e-4932 से 1.18973e + 4932 | वास्तविक का काल्पनिक मूल्य प्रकार |
cfloat | 8 बाइट्स | 1.17549e-38 + 1.17549e-38i से 3.40282e + 38 + 3.40282e + 38i | जटिल संख्या प्रकार दो झांकियों से बना है |
cdouble | 16 बाइट्स | 2.22507e-308 + 2.22507e-308i से 1.79769e + 308 + 1.79769e + 308i | जटिल संख्या प्रकार दो डबल्स से बना है |
Creal | 20 बाइट्स | 3.3621e-4932 + 3.3621e-4932i से 1.18973e + 4932 + 1.18973e + 4932i | दो वास्तविक से बना जटिल संख्या प्रकार |
निम्न उदाहरण एक फ्लोट प्रकार और इसके रेंज मान द्वारा लिया गया भंडारण स्थान प्रिंट करता है -
import std.stdio;
int main() {
writeln("Length in bytes: ", float.sizeof);
return 0;
}
जब आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं, तो यह लिनक्स पर निम्न परिणाम उत्पन्न करता है -
Length in bytes: 4
चरित्र प्रकार
निम्न तालिका मानक चरित्र प्रकारों को भंडारण आकारों और इसके उद्देश्य से सूचीबद्ध करती है।
प्रकार | भंडारण का आकार | उद्देश्य |
---|---|---|
चार | 1 बाइट | UTF-8 कोड इकाई |
wchar | 2 बाइट्स | UTF-16 कोड इकाई |
dchar | 4 निवाले | UTF-32 कोड इकाई और यूनिकोड कोड बिंदु |
निम्नलिखित उदाहरण एक चर प्रकार द्वारा लिया गया भंडारण स्थान प्रिंट करता है।
import std.stdio;
int main() {
writeln("Length in bytes: ", char.sizeof);
return 0;
}
जब आप उपरोक्त कार्यक्रम को संकलित और निष्पादित करते हैं, तो यह निम्नलिखित परिणाम उत्पन्न करता है -
Length in bytes: 1
शून्य प्रकार
शून्य प्रकार निर्दिष्ट करता है कि कोई मूल्य उपलब्ध नहीं है। इसका उपयोग दो प्रकार की स्थितियों में किया जाता है -
अनु क्रमांक। | प्रकार और विवरण |
---|---|
1 | Function returns as void डी में विभिन्न कार्य हैं जो मान नहीं लौटाते हैं या आप कह सकते हैं कि वे शून्य लौटाते हैं। बिना रिटर्न वैल्यू वाले फ़ंक्शन में रिटर्न प्रकार शून्य होता है। उदाहरण के लिए,void exit (int status); |
2 | Function arguments as void डी में विभिन्न कार्य हैं जो किसी भी पैरामीटर को स्वीकार नहीं करते हैं। बिना किसी पैरामीटर के एक फ़ंक्शन शून्य के रूप में स्वीकार कर सकता है। उदाहरण के लिए,int rand(void); |
शून्य प्रकार इस बिंदु पर आपको समझा नहीं जा सकता है, इसलिए हमें आगे बढ़ने दें और हम इन अवधारणाओं को आगामी अध्यायों में शामिल करेंगे।