Versions Compared

Key

  • This line was added.
  • This line was removed.
  • Formatting was changed.

...

TypeInnholdDefault-verdiStørrelseVerdiområde
byteHeltall08-128 til 127
shortHeltall016-32,768 til 32,767
intHeltall032-2,147,483,648 til 2,147,483,647
longHeltall064-9,223,372,036,854,775,808 til 9,223,372,036,854,775,807
floatFlyttall0.032+/- 1.4E-45 til +/- 3.4028235E+38
doubleFlyttall0.064+/- 4.9E-324 til +/- 1.7976931348623157E+308

Heltall

Det vil sjeldent være noen noe grunn til å bruke noe annet enn int når man bruker heltall. Det vil i så fall være dersom man har bruk for virkelig store tall (se over), som kan løses med et long. Eller man har strenge krav til minnesparsommelighet og skal ha store mengder heltall i array uten å trenge hele verdiområdet til int. I så fall vil et short, eller byte være en mulighet.
Dersom vi vil konvertere mellom to heltall vil dette gå fint dersom tallet er innenfor verdiområdet til den nye typen. 

 

Code Block
languagejava
titleCorrect casting
linenumberstrue
int i = 99;
byte b = (byte) i;
 
System.out.println(b);

// 99 

i er innenfor verdiområdet tilbyte

 

Code Block
languagejava
titleIncorrect casting
int i = 500;
byte b = (byte) i;
 
System.out.println(b);

// -12  

i er utenfor verdiområdet tilbyte

 

 

Code Block
languagejava
titleHigher #bits
int i = Integer.MAX_VALUE;
long l = i;	

System.out.println(l);
 
// 2147483647

Trenger ikke caste "oppover"

Flyttall

Hva flyttall angår vil det vil sjeldent være grunn til å bruke noe annet enn double. Det som er viktig å bemerke seg er at et flyttall blir mindre og mindre nøyaktig desto større det blir.

Double
også tre "merkelige" verdier som er gode å vite om:
NaN: "Not a number", NaN kan tildeles en double dersom vi prøver å utføre operasjoner som ikke lar seg gjøre. Se under, eksempel 1.
Infinity: "Uendelig", Infinity kan


 

 

De primitive talltypene i java har alle en "wrapper"-klasse. Disse klassene pakker inn den primitive talltypen, og gjør det mulig å representere den som et objekt. Dette gjøres ofte av kompilatoren og kalles da "autoboxing".
I java finnes det en Number-klasse som subklasses av de forskjellige wrapper-klassene. Number-klassen er abstrakt og et number-objekt vil alltid være en instans av en av subklassene.

...