程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> JAVA編程 >> JAVA編程入門知識 >> Java 基本數據類型

Java 基本數據類型

編輯:JAVA編程入門知識

Java 基本數據類型

變量就是申請內存來存儲值。也就是說,當創建變量的時候,需要在內存中申請空間。

內存管理系統根據變量的類型為變量分配存儲空間,分配的空間只能用來儲存該類型數據。

因此,通過定義不同類型的變量,可以在內存中儲存整數、小數或者字符。

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。

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’(即為65,535);
  • 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

Float和Double的最小值和最大值都是以科學記數法的形式輸出的,結尾的"E+數字"表示E之前的數字要乘以10的多少次方。比如3.14E3就是3.14 × 103 =3140,3.14E-3 就是 3.14 x 10-3 =0.00314。

實際上,JAVA中還存在另外一種基本類型void,它也有對應的包裝類 java.lang.Void,不過我們無法直接對它們進行操作。


引用類型

  • 在Java中,引用類型的變量非常類似於C/C++的指針。引用類型指向一個對象,指向對象的變量是引用變量。這些變量在聲明時被指定為一個特定的類型,比如Employee、Pubby等。變量一旦聲明後,類型就不能被改變了。
  • 對象、數組都是引用數據類型。
  • 所有引用類型的默認值都是null。
  • 一個引用變量可以用來引用與任何與之兼容的類型。
  • 例子:Site site = new Site("Runoob")。

Java常量

常量在程序運行時,不會被修改的量。

在 Java 中使用 final 關鍵字來修飾常量,聲明方式和變量類似:

final double PI = 3.1415927;

雖然常量名也可以用小寫,但為了便於識別,通常使用大寫字母表示常量。

字面量可以賦給任何內置類型的變量。例如:

byte a = 68;
char a = 'A'

byte、int、long、和short都可以用十進制、16進制以及8進制的方式來表示。

當使用常量的時候,前綴0表示8進制,而前綴0x代表16進制。例如:

int decimal = 100;
int octal = 0144;
int hexa =  0x64;

和其他語言一樣,Java的字符串常量也是包含在兩個引號之間的字符序列。下面是字符串型字面量的例子:

"Hello World"
"two\nlines"
"\"This is in quotes\""

字符串常量和字符常量都可以包含任何Unicode字符。例如:

char a = '\u0001';
String a = "\u0001";

Java語言支持一些特殊的轉義字符序列。

符號 字符含義 \n 換行 (0x0a) \r 回車 (0x0d) \f 換頁符(0x0c) \b 退格 (0x08) \s 空格 (0x20) \t 制表符 \" 雙引號 \' 單引號 \\ 反斜槓 \ddd 八進制字符 (ddd) \uxxxx 16進制Unicode字符 (xxxx)

自動類型轉換

整型、實型(常量)、字符型數據可以混合運算。運算中,不同類型的數據先轉化為同一類型,然後進行運算。

轉換從低級到高級。

低  ------------------------------------>  高

byte,short,char—> int —> long—> float —> double 

數據類型轉換必須滿足如下規則:

  • 1. 不能對boolean類型進行類型轉換。

  • 2. 不能把對象類型轉換成不相關類的對象。

  • 3. 在把容量大的類型轉換為容量小的類型時必須使用強制類型轉換。

  • 4. 轉換過程中可能導致溢出或損失精度,例如:

    int i =128;   
    byte b = (byte)i;
    

    因為byte類型時8位,最大值為127,所以當強制轉換為int類型值128時候就會導致溢出。

  • 5. 浮點數到整數的轉換是通過捨棄小數得到,而不是四捨五入,例如:

    (int)23.7 == 23;		
    (int)-45.89f == -45
    

自動類型轉換

必須滿足轉換前的數據類型的位數要低於轉換後的數據類型,例如: short數據類型的位數為16位,就可以自動轉換位數為32的int類型,同樣float數據類型的位數為32,可以自動轉換為64位的double類型。

實例

public class ZiDongLeiZhuan{ public static void main(String[] args){ char c1='a';//定義一個char類型 int i1 = c1;//char自動類型轉換為int System.out.println("char自動類型轉換為int後的值等於"+i1); char c2 = 'A';//定義一個char類型 int i2 = c2+1;//char 類型和 int 類型計算 System.out.println("char類型和int計算後的值等於"+i2); } }

運行結果為:

char自動類型轉換為int後的值等於97
char類型和int計算後的值等於66

解析:c1的值為字符'a',查ascii碼表可知對應的int類型值為97,'A'對應值為65,所以i2=65+1=66。

強制類型轉換

  • 1. 條件是轉換的數據類型必須是兼容的。

  • 2. 格式:(type)value type是要強制類型轉換後的數據類型 實例:

    實例

    public class QiangZhiZhuanHuan{ public static void main(String[] args){ int i1 = 123; byte b = (byte)i1;//強制類型轉換為byte System.out.println("int強制類型轉換為byte後的值等於"+b); } }

    運行結果:

    int強制類型轉換為byte後的值等於123
    

隱含強制類型轉換

  • 1. 整數的默認類型時int

  • 2. 浮點型不存在這種情況,因為在定義float類型時必須在數字後面跟上F或者f

這一節講解了Java的基本數據類型。下一節將探討不同的變量類型以及它們的用法。

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved