Java byte與char的區別

來源:互聯網
上載者:User

標籤: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
強制資料類型轉換強制轉換的格式是在需要轉型的資料前加上“( )”,然後在括弧內加入需要轉化的資料類型。有的資料經過轉型運算後,精度會丟失,而有的會更加精確,下面的例子可以說明這個問題。
 
  1. public class Demo {
  2. public static void main(String[] args){
  3. int x;
  4. double y;
  5. x = (int)34.56 + (int)11.2; // 丟失精度
  6. y = (double)x + (double)10 + 1; // 提高精度
  7. System.out.println("x=" + x);
  8. System.out.println("y=" + y);
  9. }
  10. }
運行結果:
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的區別

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.