Java 基本資料型別

suliver發表於2021-09-09

變數就是申請記憶體來儲存值。也就是說,當建立變數的時候,需要在記憶體中申請空間。

記憶體管理系統根據變數的型別為變數分配儲存空間,分配的空間只能用來儲存該型別資料。

圖片描述

因此,透過定義不同型別的變數,可以在記憶體中儲存整數、小數或者字元。

Java 的兩大資料型別:

  • 內建資料型別

  • 引用資料型別


內建資料型別

Java語言提供了八種基本型別。六種數字型別(四個整數型,兩個浮點型),一種字元型別,還有一種布林型。

byte:

  • byte 資料型別是8位、有符號的,以二進位制補碼錶示的整數;

  • 最小值是 -128(-2^7);

  • 最大值是 127(2^7-1);

  • 預設值是 0;

  • byte 型別用在大型陣列中節約空間,主要代替整數,因為 byte 變數佔用的空間只有 int 型別的四分之一;

  • 例子:byte a = 100,byte b = -50。

short:

  • short 資料型別是 16 位、有符號的以二進位制補碼錶示的整數

  • 最小值是 -32768(-2^15);

  • 最大值是 32767(2^15 - 1);

  • Short 資料型別也可以像 byte 那樣節省空間。一個short變數是int型變數所佔空間的二分之一;

  • 預設值是 0;

  • 例子:short s = 1000,short r = -20000。

int:

  • int 資料型別是32位、有符號的以二進位制補碼錶示的整數;

  • 最小值是 -2,147,483,648(-2^31);

  • 最大值是 2,147,483,647(2^31 - 1);

  • 一般地整型變數預設為 int 型別;

  • 預設值是 0 ;

  • 例子:int a = 100000, int b = -200000。

long:

  • long 資料型別是 64 位、有符號的以二進位制補碼錶示的整數;

  • 最小值是 -9,223,372,036,854,775,808(-2^63);

  • 最大值是 9,223,372,036,854,775,807(2^63 -1);

  • 這種型別主要使用在需要比較大整數的系統上;

  • 預設值是 0L;

  • 例子: long a = 100000L,Long b = -200000L。
    "L"理論上不分大小寫,但是若寫成"l"容易與數字"1"混淆,不容易分辯。所以最好大寫。

float:

  • float 資料型別是單精度、32位、符合IEEE 754標準的浮點數;

  • float 在儲存大型浮點陣列的時候可節省記憶體空間;

  • 預設值是 0.0f;

  • 浮點數不能用來表示精確的值,如貨幣;

  • 例子:float f1 = 234.5f。

double:

  • double 資料型別是雙精度、64 位、符合IEEE 754標準的浮點數;

  • 浮點數的預設型別為double型別;

  • double型別同樣不能表示精確的值,如貨幣;

  • 預設值是 0.0d;

  • 例子:double d1 = 123.4。

boolean:

  • boolean資料型別表示一位的資訊;

  • 只有兩個取值:true 和 false;

  • 這種型別只作為一種標誌來記錄 true/false 情況;

  • 預設值是 false;

  • 例子:boolean one = true。

char:

  • char型別是一個單一的 16 位 Unicode 字元;

  • 最小值是 u0000(即為 0);

  • 最大值是 uffff(即為 65535);

  • char 資料型別可以儲存任何字元;

  • 例子:char letter = 'A';。

例項

對於數值型別的基本型別的取值範圍,我們無需強制去記憶,因為它們的值都已經以常量的形式定義在對應的包裝類中了。請看下面的例子:

例項

public class PrimitiveTypeTest {      public static void main(String[] args) {          // byte          System.out.println("基本型別:byte 二進位制位數:" + Byte.SIZE);          System.out.println("包裝類:java.lang.Byte");          System.out.println("最小值:Byte.MIN_VALUE=" + Byte.MIN_VALUE);          System.out.println("最大值:Byte.MAX_VALUE=" + Byte.MAX_VALUE);          System.out.println();            // short          System.out.println("基本型別:short 二進位制位數:" + Short.SIZE);          System.out.println("包裝類:java.lang.Short");          System.out.println("最小值:Short.MIN_VALUE=" + Short.MIN_VALUE);          System.out.println("最大值:Short.MAX_VALUE=" + Short.MAX_VALUE);          System.out.println();            // int          System.out.println("基本型別:int 二進位制位數:" + Integer.SIZE);          System.out.println("包裝類:java.lang.Integer");          System.out.println("最小值:Integer.MIN_VALUE=" + Integer.MIN_VALUE);          System.out.println("最大值:Integer.MAX_VALUE=" + Integer.MAX_VALUE);          System.out.println();            // long          System.out.println("基本型別:long 二進位制位數:" + Long.SIZE);          System.out.println("包裝類:java.lang.Long");          System.out.println("最小值:Long.MIN_VALUE=" + Long.MIN_VALUE);          System.out.println("最大值:Long.MAX_VALUE=" + Long.MAX_VALUE);          System.out.println();            // float          System.out.println("基本型別:float 二進位制位數:" + Float.SIZE);          System.out.println("包裝類:java.lang.Float");          System.out.println("最小值:Float.MIN_VALUE=" + Float.MIN_VALUE);          System.out.println("最大值:Float.MAX_VALUE=" + Float.MAX_VALUE);          System.out.println();            // double          System.out.println("基本型別:double 二進位制位數:" + Double.SIZE);          System.out.println("包裝類:java.lang.Double");          System.out.println("最小值:Double.MIN_VALUE=" + Double.MIN_VALUE);          System.out.println("最大值:Double.MAX_VALUE=" + Double.MAX_VALUE);          System.out.println();            // char          System.out.println("基本型別:char 二進位制位數:" + Character.SIZE);          System.out.println("包裝類:java.lang.Character");          // 以數值形式而不是字元形式將Character.MIN_VALUE輸出到控制檯          System.out.println("最小值:Character.MIN_VALUE="                  + (int) Character.MIN_VALUE);          // 以數值形式而不是字元形式將Character.MAX_VALUE輸出到控制檯          System.out.println("最大值:Character.MAX_VALUE="                  + (int) Character.MAX_VALUE);      }  }


編譯以上程式碼輸出結果如下所示:

基本型別:byte 二進位制位數:8包裝類:java.lang.Byte最小值:Byte.MIN_VALUE=-128最大值:Byte.MAX_VALUE=127基本型別:short 二進位制位數:16包裝類:java.lang.Short最小值:Short.MIN_VALUE=-32768最大值:Short.MAX_VALUE=32767基本型別:int 二進位制位數:32包裝類:java.lang.Integer最小值:Integer.MIN_VALUE=-2147483648最大值:Integer.MAX_VALUE=2147483647基本型別:long 二進位制位數:64包裝類:java.lang.Long最小值:Long.MIN_VALUE=-9223372036854775808最大值:Long.MAX_VALUE=9223372036854775807基本型別:float 二進位制位數:32包裝類:java.lang.Float最小值:Float.MIN_VALUE=1.4E-45最大值:Float.MAX_VALUE=3.4028235E38基本型別:double 二進位制位數:64包裝類:java.lang.Double最小值:Double.MIN_VALUE=4.9E-324最大值:Double.MAX_VALUE=1.7976931348623157E308基本型別:char 二進位制位數:16包裝類:java.lang.Character最小值:Character.MIN_VALUE=0最大值:Character.MAX_VALUE=65535


來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/2370/viewspace-2807310/,如需轉載,請註明出處,否則將追究法律責任。

相關文章