一、
byte是字節數據類型、有符號型的、佔1個字節、大小範圍爲-128——127
char是字符數據類型、無符號型的、佔2個字節(unicode碼)、大小範圍爲0-65535
轉換原則
從低精度向高精度轉換
byte 、short、int、long、float、double、char
注:兩個char型運算時,自動轉換爲int型;當char與別的類型運算時,也會先自動轉換爲int型的,再做其它類型的自動轉換
數據類型的轉換,分爲自動轉換和強制轉換。自動轉換是程序在執行過程中“悄然”進行的轉換,不需要用戶提前聲明,一般是從位數低的類型向位數高的類型轉換;強制類型轉換則必須在代碼中聲明,轉換順序不受限制。
自動數據類型轉換
自動轉換按從低到高的順序轉換。不同類型數據間的優先關係如下:低--------------------------------------------->高
byte,short,char-> int -> long -> float -> double
運算中,不同類型的數據先轉化爲同一類型,然後進行運算,轉換規則如下:
操作數1類型 | 操作數2類型 | 轉換後的類型 |
---|---|---|
byte、short、char | int | int |
byte、short、char、int | long | long |
byte、short、char、int、long | float | float |
byte、short、char、int、long、float | double | double |
強制數據類型轉換
強制轉換的格式是在需要轉型的數據前加上“( )”,然後在括號內加入需要轉化的數據類型。有的數據經過轉型運算後,精度會丟失,而有的會更加精確,下面的例子可以說明這個問題。- public class Demo {
- public static void main(String[] args){
- int x;
- double y;
- x = (int)34.56 + (int)11.2; // 丟失精度
- y = (double)x + (double)10 + 1; // 提高精度
- System.out.println("x=" + x);
- System.out.println("y=" + y);
- }
- }
x=45
y=56.0
仔細分析上面程序段:由於在 34.56 前有一個 int 的強制類型轉化,所以 34.56 就變成了 34。同樣 11.2 就變成了 11 了,所以 x 的結果就是 45。在 x 前有一個 double 類型的強制轉換,所以 x 的值變爲 45.0,而 10 的前面也被強制成 double 類型,所以也變成 10.0,所以最後 y 的值變爲 56。