Java基礎「八大基本資料型別和資料型別的轉換」
1.八大基本資料型別
分為以下四類:
整形(byte、short、int、long)
布林型別(boolean)
位元組型(char)
浮點型(float、double)
具體佔幾個位元組、取值範圍(如下圖)

2.資料型別的轉換
(自動型別轉換、強制型別轉換)
Java 語言是一種強型別的語言。強型別的語言有以下幾個要求:
變數或常量必須有型別: 要求宣告變數或常量時必須宣告型別,而且只能在宣告以後才能使用。
賦值時型別必須一致: 值的型別必須和變數或常量的型別完全一致。
運算時型別必須一致: 參與運算的資料型別必須一致才能運算。
但是在實際的使用中,經常需要在不同型別的值之間進行操作,這就需要一種新的語法來適應這種需要,這個語法就是資料型別轉換。
在數值處理這部分,計算機和現實的邏輯不太一樣,對於現實來說,1和 1.0 沒有什麼區別,但是對於計算機來說,1 是整數型別,而 1.0 是小數型別,其在記憶體中的儲存方式以及佔用的空間都不一樣,所以型別轉換在計算機內部是必須的。
Java 語言中的資料型別轉換有兩種:
自動型別轉換: 編譯器自動完成型別轉換,不需要在程式中編寫程式碼。
強制型別轉換: 強制編譯器進行型別轉換,必須在程式中編寫程式碼。
由於基本資料型別中 boolean 型別不是數字型,所以基本資料型別的轉換是出了boolean 型別以外的其它 7 種類型之間的轉換。下面來具體介紹兩種型別轉換的規則、適用場合以及使用時需要注意的問題。
2.1自動型別轉換
自動型別轉換,也稱隱式型別轉換,是指不需要書寫程式碼,由系統自動完成的型別轉換。由於實際開發中這樣的型別轉換很多,所以 Java 語言在設計時,沒有為該操作設計語法,而是由 JVM 自動完成。
轉換規則:從儲存範圍小的型別到儲存範圍大的型別。
具體規則為:byte→short(char)→int→long→float→double也就是說 byte 型別的變數可以自動轉換為 short 型別。
示例程式碼:
byte b = 10;
short sh = b;
這裡在賦值時,JVM 首先將 b 的值轉換為 short 型別,然後再賦值給 sh。在型別轉換時可以跳躍。示例程式碼:
byte b1 = 100;
int n = b1;
注意問題:在整數之間進行型別轉換時,數值不發生改變,而將整數型別,特別是比較大的整數型別轉換成小數型別時,由於儲存方式不同,有可能存在資料精度的損失。
2.2強制型別轉換
強制型別轉換,也稱顯式型別轉換,是指必須書寫程式碼才能完成的型別轉換。該類型別轉換很可能存在精度的損失,所以必須書寫相應的程式碼,並且能夠忍受該種損失時才進行該型別的轉換。
轉換規則: 從儲存範圍大的型別到儲存範圍小的型別。
具體規則為: double→float→long→int→short(char)→byte
語法格式為: (轉換到的型別)需要轉換的值
示例程式碼:
double d = 3.10;
int n = (int)d;
這裡將 double 型別的變數 d 強制轉換成int 型別,然後賦值給變數 n。需要說明的是小數強制轉換為整數,採用的是“去 1 法”,也就是無條件的捨棄小數點的所有數字,則以上轉換出的結果是 3。
整數強制轉換為整數時取數字的低位,例如 int 型別的變數轉換為 byte 型別時,則只去int 型別的低 8 位(也就是最後一個位元組)的值。
示例程式碼:
int n = 123;
byte b = (byte)n;
int m = 1234;
byte b1 = (byte)m;、
則 b 的值還是 123,而 b1 的值為-46。b1 的計算方法如下:m 的值轉換為二進位制是10011010010,取該數字低8位的值作為b1的值,則b1的二進位制值是11010010,按照機器數的規定,最高位是符號位,1 代表負數,在計算機中負數儲存的是補碼,則該負數的原碼是 10101110,該值就是十進位制的-46。
注意問題:強制型別轉換通常都會儲存精度的損失,所以使用時需要謹慎。
總結:
自動型別轉換是從儲存範圍小的型別到儲存範圍大的型別。
強制型別轉換是從儲存範圍大的型別到儲存範圍小的型別。