java——Byte類/包裝類的使用說明
Byte類/包裝類
包裝類是一個常量類,可實例化 (意義:幫助對應的數據類型進行數據類型)
java數據類型包括內置數據類型和引用數據類型
內置數據類型 :含6中數字類型(四個整數型,兩個浮點型),一種字符類型,還有佈爾類型
byte
byte:數據類型占用1個字節=8bit,以二進制補碼表示的整數
取值范圍:默認值為0,最小值為-128(-2^7);最大值是127(2^7-1)
數據類型 | 關鍵字 | 內存中占用字節數 | 取值范圍 | 默認值 |
佈爾型 | boolean | 1 | true/false | FALSE |
字節型 | byte | 1 | -128~127 | 0 |
短整型 | short | 2 | -2^15~2^15-1 | 0 |
整型 | int | 4 | -2^31~2^31-1 | 0 |
長整型 | long | 8 | -2^63~2^63-1 | 0 |
字符型 | char | 2 | 0~2^16-1 | ‘\u000’ |
單精度浮點型 | float | 4 | 1.4013E-45~3.4028E+38 | 0.0F |
雙精度浮點型 | double | 8 | 4.9E-324~1.7977E+308 | 0.0D |
用途:byte類型用在大型數組中節約空間,主要代替整數,因byte變量占用內存的空間隻有int類型的1/4;不足是這個數取值范圍大,byte不能全部替代
常用方法
A.構造方法
public Byte(byte value) public Byte(String s)
B.普通方法+類方法(對數據類型做轉換)
piublic byte byteValue() public short shortValue() public int intVlaue() public long longValue() public float floatValue() public double doubleValue() public String toString() public static String toString(byte b)
包裝類和基本數據類型的對象關系
註:常量類是否可以被實例化主要看構造方法
package com.youceedu.test.wrapper; public class TestByte { public static void main(String[] args) { // TODO Auto-generated method stub byte a = 9; byte b = -7; String result = Byte.toString(a); Byte c = new Byte((byte) 9); System.out.println(c.floatValue()); System.out.println(result+b); } }
補充:java的byte數據類型總結||二進制的原碼、反碼和補碼
二進制的原碼、反碼和補碼
原碼就是二進制定點表示法,即最高位為符號位,“0”表示正,“1”表示負,其餘位表示數值的大小。
反碼表示法規定:正數的反碼與其原碼相同;負數的反碼是對其原碼逐位取反,但符號位除外。
補碼表示法規定:正數的補碼與其原碼相同;負數的補碼是在其反碼的末位加1。
正數
首位表示符號位,原碼、反碼和補碼都是本身。
負數
如何計算負數在計算機中的二進制(即它的補碼)?
首先對負數的絕對值取反,然後+1得到負數的補碼。
例如:byte a=-5
-5的絕對值=5 5的二進制表示是 0000 0101 取反得到 1111 1010 +1運算得到 1111 1011 ,那麼1111 1011就是-5的補碼。
也可以這樣,用原碼計算
例如:byte a=-5 原碼表示 1000 0101
計算其反碼為 1111 1010
計算其補碼為 1111 1011
所以 -5在計算機中表示為1111 1011
byte
byte的取值范圍為什麼是-128~127
byte 表示一個字節,8bit,其中最高位是符號位。因此,最大值為 0111 1111,即127;最小值是負數為 1000 0000(規定)【其他數據類型的最大最小值也可以這樣以此類推】。在計算機中二進制都是以補碼的形式表示的,我們也可以這樣來理解,為什麼最小是-128
最小負數補碼表示為:1000 0000
由補碼計算原碼:
1000 0000 作-1 運算 得到 0111 1111,取反 1000 0000 因為負數的補碼是其絕對值取反,即10000000為最小負數的絕對值,而10000000的十進制表示是128,所以最小負數是-128
byte與ASCII
標準ASCII 碼也叫基礎ASCII碼,使用7 位二進制數(剩下的1位二進制為0)來表示所有的大寫和小寫字母,數字0 到9、標點符號, 以及在美式英語中使用的特殊控制字符。
ASCII碼表示的范圍是0~127 剛好byte類型可以覆蓋到。因此byte類型和ASCII可以互相轉換。可以根據ASCII對照表進行查看http://tool.oschina.net/commons?type=4
當byte類型的變量的值實時是在”單引號裡面的時候,該byte變量的值表示的是ASCII碼,可以通過ASCII對照表查看其真實的數值。
比如:
public class ByteTest { public static void main(String args[]) { byte a = 'a'; byte b = 'B'; byte c = '4'; System.out.println("a=" + a); System.out.println("b=" + b); System.out.println("c=" + c); } }
輸出:
a=97 b=66 c=52
byte&0xff的作用
byte->int 因為byte是8位,而int是32位,當byte類型轉換為int類型的時候,會自動用符號位補足高位。例如 -5 1111 1011 轉為int 類型會表示為 1111 1111 1111 1111 1111 1111 1111 1011 其表示的十進制的數值不變。
有的時候,我們隻想保留二進制的補碼形式,我們可以用byte&0xff。0xff是十六進制,默認是int類型,其二進制表示為 0000 0000 0000 0000 0000 0000 1111 1111 將byte類型的數值跟0xff作&操作,可以將高24位變為0,保留低8位。當然對應的十進制數也發生瞭變化。(相當於將byte變成無符號int類型)
例如:byte a=-5 ((int)-5)&0xff
1111 1111 1111 1111 1111 1111 1111 1011 & 0000 0000 0000 0000 0000 0000 1111 1111 = 0000 0000 0000 0000 0000 0000 1111 1011
int強轉換為byte
例如:
int a=234 byte b=(byte)a –>得到b=-22 因為234已經超出瞭byte類型的表示范圍,強轉會直接丟棄高位,保留低8位。
int類型的234的二進制表示為:1110 1010【高24位全是0】 強轉為byte類型,舍棄高24位得到1110 1010 ,第一位為符號位1,得到一個負數-22。
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。如有錯誤或未考慮完全的地方,望不吝賜教。