Java 基本數據類型

Java 基本數據類型

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

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

所以,經過定義不一樣類型的變量,能夠在內存中儲存整數、小數或者字符。函數

Java的兩大數據類型:大數據

  • 內置數據類型
  • 引用數據類型

內置數據類型

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

byte:code

  • 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,485,647(2^31 - 1);
  • 通常地整型變量默認爲int類型;
  • 默認值是0;
  • 例子:int a = 100000, int b = -200000。

long:ci

  • 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 × 10³=3140,3.14E-3 就是 3.14 x 10-³ =0.00314。

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

引用類型

  • 引用類型變量由類的構造函數建立,可使用它們訪問所引用的對象。這些變量在聲明時被指定爲一個特定的類型,好比Employee、Pubby等。變量一旦聲明後,類型就不能被改變了。
  • 對象、數組都是引用數據類型。
  • 全部引用類型的默認值都是null。
  • 一個引用變量能夠用來引用與任何與之兼容的類型。
  • 例子:Animal animal = new Animal(「giraffe」)。

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)
相關文章
相關標籤/搜索