標籤:unicode 亂碼 java
一、
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。
著作權聲明:本文為博主原創文章,未經博主允許不得轉載。
Java byte與char的區別