1. 程式人生 > >Java基本數據類型大總結

Java基本數據類型大總結

ring 布爾 通過 記錄 hex 方式 引號 16進制 兩個

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(即為65,535);
    • char 數據類型可以儲存任何字符;

例子:char letter = ‘A‘;。


基本類型: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


Bool :false
Byte :0
Character:
Double :0.0
Float :0.0
Integer :0
Long :0
Short :0
String :null

上面是默認值


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

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

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

自動類型轉換

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

轉換從低級到高級。

  ------------------------------------>  

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

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

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

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

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

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

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

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

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

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

Java 裏使用 long 類型的數據一定要在數值後面加上 L,否則將作為整型解析:

char a = ‘S‘; char 後面賦值要用單引號,因為是字符型數據類型

String a = "I AM FINE"; String 後面賦值要用雙引號,因為是字符串數據類型


數據類型轉換的補充

1、包裝類過渡類型轉換

一般情況下,我們首先聲明一個變量,然後生成一個對應的包裝類,就可以利用包裝類的各種方法進行類型轉換了。例如:

當希望把float型轉換為double型時:

float f1=100.00f;
Float F1=new Float(f1);
double d1=F1.doubleValue();//F1.doubleValue()為Float類的返回double值型的方法

簡單類型的變量轉換為相應的包裝類,可以利用包裝類的構造函數。即:Boolean(boolean value)、Character(char value)、Integer(int value)、Long(long value)、Float(float value)、Double(double value)

而在各個包裝類中,總有形為××Value()的方法,來得到其對應的簡單類型數據。利用這種方法,也可以實現不同數值型變量間的轉換,例如,對於一個雙精度實型類,intValue()可以得到其對應的整型變量,而doubleValue()可以得到其對應的雙精度實型變量。

2、字符串與其它類型間的轉換

其它類型向字符串的轉換

  • 調用類的串轉換方法:X.toString();
  • 自動轉換:X+"";
  • 使用String的方法:String.valueOf(X);

3、字符串作為值,向其它類型的轉換

1、先轉換成相應的封裝器實例,再調用對應的方法轉換成其它類型

例如,字符中"32.1"轉換double型的值的格式為:new Float("32.1").doubleValue()。也可以用:Double.valueOf("32.1").doubleValue()

2、靜態parseXXX方法

String s = "1";
byte b = Byte.parseByte( s );
short t = Short.parseShort( s );
int i = Integer.parseInt( s );
long l = Long.parseLong( s );
Float f = Float.parseFloat( s );
Double d = Double.parseDouble( s );


 

Java基本數據類型大總結