1. double
प्रकार
जावा double
वास्तविक (आंशिक) संख्याओं के साथ काम करने के लिए प्रकार प्रदान करता है। यह 8 bytes
स्मृति में रहता है (प्रकार के रूप में दो बार ) और मूल्यों को रेंज int
में स्टोर कर सकता है । तुलना के लिए: प्रकार से श्रेणी में मान संग्रहीत कर सकता है ।-1.7*10308
+1.7*10308
int
-2*109
+2*109
वास्तविक संख्या में, भिन्नात्मक भाग को दशमलव बिंदु के बाद लिखा जाता है। उदाहरण के लिए, 123.456, या 2.5, या 100.00, या 0.01। जब कंप्यूटर ऐसी संख्याओं से निपटते हैं, तो हम उन्हें फ़्लोटिंग पॉइंट नंबर कहते हैं।
वैसे, double
प्रकार के अतिरिक्त, हमारे पास float
प्रकार भी है (जो आकार में केवल 4 बाइट है)। इसका नाम फ्लोटिंग पॉइंट से आता है । और नाम आता है डबल फ्लोटdouble
से । A, a : बनाम से दोगुना बड़ा है । इसे डबल प्रिसिजन फ्लोटिंग-पॉइंट नंबर भी कहा जाता है ।double
float
8 bytes
4
2. एक double
प्रकार बनाना
वास्तविक संख्याओं को संग्रहीत करने के लिए दोहरे प्रकार का उपयोग किया जाता है। कोड में एक चर बनाने के लिए जो वास्तविक संख्याओं को संग्रहीत कर सकता है, आपको इस तरह के एक कथन का उपयोग करने की आवश्यकता है:
double name;
जहाँ नाम चर का नाम है। उदाहरण:
कथन | विवरण |
---|---|
|
एक वास्तविक price चर बनाया जाता है |
|
एक वास्तविक weight चर बनाया जाता है |
|
एक वास्तविक lightSpeed चर बनाया जाता है |
प्रकार के साथ int
, आप double
एक साथ कई चर बनाने के लिए आशुलिपि का उपयोग कर सकते हैं:
double name 1, name 2, name 3;
और यहां तक कि उन्हें तुरंत मान भी दें:
double name 1 = value 1, name 2 = value 2, name 3 = value 3;
उदाहरण:
कथन | टिप्पणी |
---|---|
|
चर भंडार5.0 |
|
चर भंडार2.0 |
|
3. पूर्णांक और वास्तविक संख्या निर्दिष्ट करना
यह बुरा होगा यदि पूर्णांकों को केवल int
चरों को और वास्तविक संख्याओं को केवल double
चरों को सौंपा जा सकता है। हम दो प्रकार की संख्याओं के बीच रूपांतरण करने में सक्षम होना चाहते हैं। और जावा यह क्षमता प्रदान करता है।
सबसे पहले, वास्तविक और पूर्णांक संख्या दोनों को double
चर के लिए निर्दिष्ट किया जा सकता है। पूर्णांक निर्दिष्ट करते समय, वे केवल वास्तविक संख्याओं में परिवर्तित हो जाते हैं। बेशक, प्रक्रिया में कुछ सटीकता खो सकती है।
कथन | टिप्पणी |
---|---|
|
चर भंडार5.0 |
|
चर भंडार2.0 |
|
चर x भंडार1000000.0 |
दूसरा, यदि एक पूर्णांक और एक वास्तविक संख्या किसी अभिव्यक्ति में शामिल हैं, तो पूर्णांक को पहले एक वास्तविक संख्या में परिवर्तित किया जाता है और उसके बाद ही अन्य वास्तविक संख्या के साथ संक्रिया की जाती है।
कथन | टिप्पणी |
---|---|
|
चर x भंडार5000.0 |
|
नंबर 10 स्क्रीन पर प्रदर्शित होगा |
|
नंबर 10.0 स्क्रीन पर प्रदर्शित होगा |
int
और अंत में, चरों को वास्तविक संख्या निर्दिष्ट करना भी संभव है । जब हम ऐसा करते हैं, तो वास्तविक संख्या के भिन्नात्मक भाग को हटा दिया जाता है - संख्या को निकटतम पूर्ण संख्या तक गोल कर दिया जाता है।
इसके अतिरिक्त, कंपाइलर को प्रोग्रामर को स्पष्ट रूप से दस्तावेज करने की आवश्यकता होती है कि क्या हो रहा है (यह सुनिश्चित करने के लिए कि अन्य प्रोग्रामर समझते हैं कि भिन्नात्मक भाग गिराया जा रहा है)। सामान्य तौर पर, ऐसा रूपांतरण कोड में ऐसा दिखता है:
integer_variable = (int)(real_number);
उदाहरण:
कथन | टिप्पणी |
---|---|
|
चर x भंडार5 |
|
चर x भंडार5 |
|
चर x भंडार11 |
4. जावा में पूर्णांकों और वास्तविक संख्याओं को विभाजित करना
एक पूर्णांक को एक पूर्णांक से विभाजित करते समय, शेषफल हमेशा हटा दिया जाता है। फिर हम कैसे प्राप्त करने के 5
लिए विभाजित कर सकते हैं ?2
2.5
सबसे पहले, ऐसा लगता है कि सही विकल्प है:
double d = 5 / 2;
लेकिन यह इतना आसान नहीं है. यहाँ समस्या यह है कि जावा मशीन पहले के मान की गणना करती है और उसके बाद ही चर 5 / 2
को परिणाम देती है । d
और 5 / 2
ऑपरेशन पूर्णांक विभाजन है। इसका मतलब है d
शामिल होगा 2
या, अधिक सटीक होने के लिए,2.0
सही समाधान विभाजन में शामिल संख्याओं में से कम से कम एक वास्तविक संख्या के रूप में लिखना है (यानी दशमलव बिंदु के साथ):
double d = 5.0 / 2;
double d = 5 / 2.0;
double d = 5.0 / 2.0;
प्रत्येक भाव में, d
शामिल होगा2.5
लेकिन क्या होगा अगर हम चर के साथ काम कर रहे हैं? क्या होगा अगर हमारे पास ऐसा कोड है ?:
int a = 5;
int b = 2;
double d = a / b;
यहाँ एक चालाक (और स्पष्ट) समाधान है - जावा मशीन को वास्तविक संख्या के रूप में एक से गुणा करके चर को वास्तविक संख्या में बदलने के लिए मजबूर करें ( 1.0
)
int a = 5;
int b = 2;
double d = a * 1.0 / b;
ध्यान दें कि गुणा और भाग की समान प्राथमिकता है, और बाएं से दाएं की ओर किया जाता है। इसका अर्थ है कि यह मायने रखता है कि हम 1.0 को कहाँ गुणा करते हैं।
उदाहरण:
कथन | अमल का आदेश | परिणाम |
---|---|---|
|
(1.0 * a) / b; |
2.5 |
|
(a * 1.0) / b; |
2.5 |
|
(a / b) * 1.0; |
2.0 |
GO TO FULL VERSION