Posted on 2008-08-06 11:47
stonebow 閱讀(2195)
評論(1) 編輯 收藏 所屬分類:
JAVA遇到問題
由于byte的表示范圍是-128到127,如果使用下面方法轉換將會發生致命的錯誤:
int num = 40000;
byte first = num/256;
byte second = num%256;
這樣,只要first或second超過127,就會溢出,從而合并起來的int數值會和原數值不一致。
int input2 = 130;
byte a3 = (byte) input2;
input2 = a3;
System.out.println(input2);
對于上述代碼,結果為-126,而不是開始的130,也是溢出的問題,所以一定要注意。
解決方法:
第一種:較為不徹底,對于正整數來說,可以除以127,從而使byte不會溢出
第二種:轉化的時候按位操作,從而不使用強制轉化損失精度:
// 將iSource轉為長度為iArrayLen的byte數組,字節數組的低位是整型的低字節位
public static byte[] toByteArray(int iSource, int iArrayLen)
{
byte[] bLocalArr = new byte[iArrayLen];
for ( int i = 0; (i < 4) && (i < iArrayLen); i++)
{
bLocalArr[i] = (byte)( iSource>>8*i & 0xFF );
}
return bLocalArr;
}
// 將byte數組bRefArr轉為一個整數,字節數組的低位是整型的低字節位
public static int toInt(byte[] bRefArr)
{
int iOutcome = 0;
byte bLoop;
for ( int i =0; i<4 ; i++)
{
bLoop = bRefArr[i];
iOutcome+= (bLoop & 0xFF) << (8 * i);
}
return iOutcome;
}