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 కంటే రెండు రెట్లు పెద్దది : వర్సెస్ . దీనిని డబుల్ ప్రెసిషన్ ఫ్లోటింగ్ పాయింట్ నంబర్ అని కూడా అంటారు .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