??引言??
大家好啊,我是執梗,Java有八大基本型別,很多同學只對經常使用的int型別比較了解,有的同學是剛從C語言轉入Java學習,誤以為兩者的基本資料型別完全相同,這也是大錯特錯的,今天這本Java基本資料型別全決議大字典,可以幫助你直接通過目錄找到你想要了解某一種基本資料型別,
??問答小劇場??
以下會產生資訊丟失的型別轉換是( )
A.float a=10;
B.int a =(int)8846.0;
C.byte a=10;int b=-a
D.double d=100
可直接跳轉至結尾看答案加決議
??目錄??
🎃1.八大基本資料型別族譜
🎃2.八大型別細節決議
🎨1.byte
🎨2.short
🎨3.int
🎨4.long
🎨5.char
🎨6.float
🎨7.double
🎨8.boolean
🎃2.小劇場解答
🎃1.八大基本資料型別族譜
Java的八大基本資料型別包括——byte、char、short、int、long、float、double、boolean(不包括String), 其中byte、shory、int、long為整數型別,char為字符型別、float、double為浮點數型別(也可以理解為小數型別),boolean為布爾型別,只能取boolean或者false,
八大基本資料型別基本資訊(建議收藏):

🎃2.八大型別細節決議
🎨1.byte
byte是Java八種資料型別之一的位元組關鍵字,我們通常說的占幾個位元組說的就是它了,byte由8個bit位組成,一個bit位指的是二進制的一位,也就是只能取0和1,但我們Java中除了boolean和char不區分正負號,其余型別都是有正負的,為了表示正負Java中用最高位的1個bit位來表示正負,0為正,1為負,我們直接通過二進制來找一找byte的取值范圍
//首位為0表示正數,為1表示負數
String a="01111111";
System.out.println(Integer.parseInt(a,2));//127
從結果來看我們知道,當后面7位全取1首位取0時,byte能取到最大值為127,當首位為1時,取到最小負數為-127,誒?不對啊,上面明明說byte取值是[-128,127],照你這么說-128去哪了?別急,其實大家都忽略了一個問題,0是沒有正負的,所以這時你不能說無論首個bit位是0還是1都當做0,這樣肯定是不行的,不僅容易出問題還浪費資源空間,所以我們規定當為10000000時,看上去好像是-0,我們就把它當做為-128,這個大家了解一下即可,因為其中還涉及到一些正反補碼的知識,
byte a= (byte)0B10000000;
System.out.println(a);//-128
1.賦值報錯以及強轉原則
先看上圖的報錯資訊,首先a和b報錯,提示我們提供的型別不對,這是因為我們賦的值超出了byte的取值范圍,而且在Java中默認的整數型別為int,浮點數型別為double ,所以它這提示我們提供的型別不對,有的人肯定就說了,誒你不會強轉嗎?在我們Java中大的資料型別可以強轉成小的資料型別 ,難道你不知道嗎?別急,當然可以強轉,我們試試給兩個超出byte范圍內的值強轉會怎樣
byte a=(byte)10000;
System.out.println(a);//16
會發現10000強制后得到了16,它是怎么得來的呢?別急,我們來看看10000和16的的二進制表示
System.out.println(Integer.toBinaryString(10000));//100111 00010000
System.out.println(Integer.toBinaryString(16));//00010000
發現沒,10000的二進制表示的后八位,就是16的二進制表示,因為int型別占4個位元組也就是32個bit位,而我們byte只有8個,所以當int強轉為byte時,我們只取int的后8個bit位,取到多少則強轉為多少,但是這里要注意我舉的例子強轉前后都是正數,當有負數時會發現好像我們的結論不成立,那是因為計算機在儲存負數時是以反碼的格式存盤,我們平時看見的二進制都是正碼,想深入了解的同學可以找文章了解一下,想自己舉例驗證的盡量都舉一個強轉前后都為正數的例子,
2.參與運算升級為int

有些同學肯定會很納悶,誒不對啊,我這兩個byte一個10一個20相加得到30,30也沒超出byte取值范圍,咋說我得到的結果是int呢?這是因為在Java中有規定:在有byte、char、short參與運算時,得到的結果會自動提升為int型別,這是很多初學者都忽略的問題,大家一定要了解,這時是需要進行強轉的,當然因為30并未超出byte取值范圍,強轉后c也為30,
🎨2.short
這里將short放到前面講,是因為它和byte的性質其實差不多,只不過它的取值范圍更大一些,但依舊小于int,short也是一個短整型資料型別,它占兩個位元組,那也就是16個bit位,我們同樣通過代碼嘗試找一下它的最大值,
public static void main(String[] args) {
String a="0111111111111111";//首位bit用來表示正負
System.out.println(Integer.parseInt(a,2));//32767
}
我們很容易可以看出short可以取得的最大值為32767,當首位bit位為1時則取到-32767,同樣要留心像byte一樣-0的情況,這時我們定義它的值為-32768,所以short的取值范圍為[-32768,32767] ,short的易錯點和byte其實一樣,當給short賦值一個超出short的取范圍時,數默認為int型別,因為short只占16個bit位,int型別占32個,則會舍掉前16個留后16個給short,同樣short參與運算時也會升級為int,所以除了取值范圍,short和byte的性質差不多,short也可以說是八大基本資料型別可以說是最冷門的一個了,
🎨3.int
作為最常用的資料型別,int相信是大家最熟悉的基本資料型別了,它占4個位元組,也就是32個bit位,這里就不再重復上面步驟,因為是32位,除去一位符號位,在這順手一提,Java中的基本資料型別中是沒有無符號型別的,所以還剩31個bit位表示值,則取值范圍為[-2147483648 ~ 2147483647] ,之所以int能成為我們最常用的基本資料型別,就是因為它的取值范圍足夠我們大多數的場景使用,選太大的long型別占用空間大浪費資源,選太小的short和byte容易溢位,而int的取值范圍則恰好合適,
🎨4.long
long型別屬于長整數資料型別,它占8個位元組,也就是64個bit位,所以它的取值范圍為[-9223372036854774808 ~ 9223372036854774807],可以看出這個數是非常大的,但是因為太占記憶體,我們很少使用它,通常在運算時可能超出int型別造成溢位,我們才會使用long型別,如果直接給long型別賦值時,我們需要注意在末尾加上L或l,這是為什么呢?我們來用代碼看看

發現沒,我特意舉的這個例子,當數在int范圍內它沒有報錯,當超過int了它居然說整數過大?我long型別最大能取9223372036854774807你居然敢說我過大?難道你把我當成int了?你還真別說,JVM真把你當成int了,因為Java中整數型別都默認為int,你這是一個超過int型別的數它當然會提示過大,所以我們最好養成習慣,在給long型別賦值時,最好在末尾加上個L,告訴JVM我這是個long型別的值,

🎨5.char
char型別屬于字符型別,也是我們用的比較多的型別,它的存盤占2個位元組,也就是16個bit位,和short一樣,那取值范圍一樣嗎?當然不一樣啦!char是取不了負號的,所以它不需要用1個bit位來表示正負,所以它的取值范圍是[0,65535],有的人肯定納悶了,誒不對啊,char不是字符型別嗎?那不是應該是什么a啊b啊這種字符嗎?這就涉及到ACSII表了,我們的每個字符都可以用一個整數去表示,所以當你賦值一個合法范圍內的整數,它就會自動轉換為對于的字符,具體是什么字符就要去記一下ACSII表了
char a=97;
char b=98;
System.out.println(a);//a
System.out.println(b);//b
如上圖,97對于的為字符'a',98對于的為字符'b',所以大家這里記住,26個小寫的字母對應的ACSII表是從[97,122],
這里也要注意,char參與運算時,也是會升級為int型別,這里我們在前面提過,如果這時我們將結果賦值給char就會無法通過編譯,需要進行強轉, 就像如圖報錯,大家要注意這個細節,

當我們給char型別賦值一個超出取值范圍的整數時,編譯器此時會報錯,這時我們需要進行強轉,因為int是32位bit,char只有16位,所以char只會取int的后16位,然后轉化為對于的字符,
🎨6.float
float是浮點數型別中的單精度,在計算機中占用4個位元組,也就是32個bit位,有效的位數為7位,浮點數型別也就是我們的小數型別,通常我們在給float賦值時,因為在其末尾加上f,以告知jvm我們這是float型別,我們直接給一個小數賦值,它會出現下面這種情況,
這是為什么呢?在整數型別中,我們默認的型別為int,而在浮點數型別中我們默認的型別為double,你給float賦值一個double當然會報錯,這時就需要你進行強轉,這時就會有損失精度的可能性,那為什么可以給float賦值一個int型別的值呢?雖然float雖然和int一樣都占4個位元組,但浮點數型別是比整數型別更大的,所以我們給float賦值int型別是可以的,它會自動加上小數部分,當給int賦值float時則會報錯,需要強轉,強轉后所有的小數部分都會丟失, 
🎨7.double
double是Java中基本資料型別中浮點數型別的默認型別,它占八個位元組,和long一樣,開銷還是比較大的,它是雙精度,很多人好奇雙精度和單精度有什么區別?其實也就是范圍的問題,double有效的位數為16位,浮點數的使用唯一要記住的就是,能盡量使用float就float,因為double實在太占記憶體,而且運行速度慢于float,double賦值給float需要進行強轉,即使有可能輸出的值并未改變,

double也是除去boolean型別里最大的資料型別,它可以強轉為其余六種資料型別,不過當然會有精度的損失,將這六種資料型別賦值給double它都可以接收,
🎨8.boolean
作為八大基本資料型別最特殊的一種,boolean顯得有些格格不入,它只占一個位元組,因為它只有兩種取值,boolean和false,這里需要提醒大家的是,C語言中可以用0和非0分別代表false和true,但這在Java中是不允許的,boolean型別也不可以接收其他基本資料型別的值,其他的基本型別也不可以強轉為Boolean,
🎃2.小劇場解答
答案選B,
產生精度丟失只會出現在強轉的情況下,也就是大的資料型別轉為小的,在這里只有B選項產生了強轉,由float轉為int,
轉載請註明出處,本文鏈接:https://www.uj5u.com/houduan/402718.html
標籤:java
上一篇:資料結構復習題
