डी प्रोग्रामिंग - डेटा प्रकार

डी प्रोग्रामिंग भाषा में, डेटा प्रकार विभिन्न प्रकारों के चर या कार्यों की घोषणा के लिए उपयोग की जाने वाली एक व्यापक प्रणाली को संदर्भित करते हैं। एक चर का प्रकार यह निर्धारित करता है कि यह भंडारण में कितना स्थान रखता है और संग्रहीत बिट पैटर्न की व्याख्या कैसे की जाती है।

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);

शून्य प्रकार इस बिंदु पर आपको समझा नहीं जा सकता है, इसलिए हमें आगे बढ़ने दें और हम इन अवधारणाओं को आगामी अध्यायों में शामिल करेंगे।