在JAVA中一共有八種基本數(shù)據(jù)類型,他們分別是
byte、short、int、long、float、double、char、boolean
整型
其中byte、short、int、long都是表示整數(shù)的,只不過他們的取值范圍不一樣
byte的取值范圍為-128~127,占用1個(gè)字節(jié)(-2的7次方到2的7次方-1)
short的取值范圍為-32768~32767,占用2個(gè)字節(jié)(-2的15次方到2的15次方-1)
int的取值范圍為(-2147483648~2147483647),占用4個(gè)字節(jié)(-2的31次方到2的31次方-1)
long的取值范圍為(-9223372036854774808~9223372036854774807),占用8個(gè)字節(jié)(-2的63次方到2的63次方-1)
可以看到byte和short的取值范圍比較小,而long的取值范圍太大,占用的空間多,基本上int可以滿足我們的日常的計(jì)算了,而且int也是使用的最多的整型類型了。
在通常情況下,如果JAVA中出現(xiàn)了一個(gè)整數(shù)數(shù)字比如35,那么這個(gè)數(shù)字就是int型的,如果我們希望它是byte型的,可以在數(shù)據(jù)后加上大寫的B:35B,表示它是byte型的,同樣的35S表示short型,35L表示long型的,表示int我們可以什么都不用加,但是如果要表示long型的,就一定要在數(shù)據(jù)后面加“L”。
浮點(diǎn)型
float和double是表示浮點(diǎn)型的數(shù)據(jù)類型,他們之間的區(qū)別在于他們的精確度不同
float 3.402823e+38 ~ 1.401298e-45(e+38表示是乘以10的38次方,同樣,e-45表示乘以10的負(fù)45次方)占用4個(gè)字節(jié)
double 1.797693e+308~ 4.9000000e-324 占用8個(gè)字節(jié)
double型比float型存儲(chǔ)范圍更大,精度更高,所以通常的浮點(diǎn)型的數(shù)據(jù)在不聲明的情況下都是double型的,如果要表示一個(gè)數(shù)據(jù)是float型的,可以在數(shù)據(jù)后面加上“F”。
浮點(diǎn)型的數(shù)據(jù)是不能完全精確的,所以有的時(shí)候在計(jì)算的時(shí)候可能會(huì)在小數(shù)點(diǎn)最后幾位出現(xiàn)浮動(dòng),這是正常的。
boolean型(布爾型)
這個(gè)類型只有兩個(gè)值,true和false(真和非真)
boolean t = true;
boolean f = false;
char型(文本型)
用于存放字符的數(shù)據(jù)類型,占用2個(gè)字節(jié),采用unicode編碼,它的前128字節(jié)編碼與ASCII兼容
字符的存儲(chǔ)范圍在\u0000~\uFFFF,在定義字符型的數(shù)據(jù)時(shí)候要注意加' ',比如 '1'表示字符'1'而不是數(shù)值1,
char c = ' 1 ';
我們?cè)囍敵?/span>c看看,System.out.println(c);結(jié)果就是1,而如果我們這樣輸出呢System.out.println(c+0);
結(jié)果卻變成了49。
如果我們這樣定義c看看
char c = ' \u0031 ';輸出的結(jié)果仍然是1,這是因?yàn)樽址?/span>'1'對(duì)應(yīng)著unicode編碼就是\u0031
char c1 = 'h',c2 = 'e',c3='l',c4='l',c5 = 'o';
System.out.print(c1);System.out.print(c2);System.out.print(c3);System.out.print(c4);Sytem.out.print(c5);
String
在前面我們看到過這樣的定義:
String s = "hello";
System.out.println(s);跟上面的5條語(yǔ)句組合起來(lái)的效果是一樣的,那么String是個(gè)什么呢?String是字符串,它不是基本數(shù)據(jù)類型,它是一個(gè)類。