前段時(shí)間在工作中遇到一個(gè)問(wèn)題,將整數(shù)作為數(shù)據(jù)傳輸,因?yàn)閿?shù)據(jù)包留給我們的字節(jié)數(shù)也不多,所以需要將int類(lèi)型轉(zhuǎn)化為byte[]存放。需要注意的是在java和C#中,byte的取值范圍并不一致。
這里貼出C#代碼,java的實(shí)現(xiàn)是一樣的。
int轉(zhuǎn)字節(jié)數(shù)組
/// </summary>
/// <param name="number"></param>
/// <returns></returns>
private static byte[] Int32ToBytes(uint number)
{
//int numCopy = number;
byte[] bs = new byte[4];
byte a = (byte)(number >> 24);
byte b = (byte)((number & 0xff0000) >> 16);
byte c = (byte)((number & 0xff00) >> 8);
byte d = (byte)(number & 0xff);
bs[0] = a;
bs[1] = b;
bs[2] = c;
bs[3] = d;
return bs;
}
unit為無(wú)符號(hào)整型,可表示0-(2^32-1)的整數(shù),byte類(lèi)型可表示0~255的整數(shù)。用二進(jìn)制表示unit是32位,byte為8位,所以將unit的劃分為4個(gè)8位分別byte中就可以了。
byte a = (byte)(number >> 24);
將number右移24位,只留下最高8位,放入a中,這里int轉(zhuǎn)byte還需要一個(gè)強(qiáng)轉(zhuǎn)。
byte b = (byte)((number & 0xff0000) >> 16);
將number的最高8位置0,第二高8位右移到最低8位,放入到b中,c、d也是這樣賦值。
字節(jié)數(shù)組轉(zhuǎn)int
private static uint BytesToInt32(byte[] bs)
{
if (bs == null || bs.Length != 4)
{
throw new EncryptionException(ErrorCode.defaultCode, "傳入數(shù)組長(zhǎng)度不為4");
}
//獲取最高八位
uint num1 = 0;
num1 = (uint)(Convert.ToInt32(num1) ^ (int)bs[0]);
num1 = num1 << 24;
//獲取第二高八位
uint num2 = 0;
num2 = (uint)(Convert.ToInt32(num2) ^ (int)bs[1]);
num2 = num2 << 16;
//獲取第二低八位
uint num3 = 0;
num3 = (uint)(Convert.ToInt32(num3) ^ (int)bs[2]);
num3 = num3 << 8;
//獲取低八位
uint num4 = 0;
num4 = (uint)(Convert.ToInt32(num4) ^ (int)bs[3]);
return num1 ^ num2 ^ num3 ^ num4;
}
byte轉(zhuǎn)int的思路,先將每個(gè)byte位轉(zhuǎn)為一個(gè)32位的整數(shù),再將4個(gè)整數(shù)做異或,這樣就把4個(gè)8位放到一個(gè)整數(shù)當(dāng)中。
總結(jié)
byte和int類(lèi)型在計(jì)算機(jī)底層其實(shí)都是用二進(jìn)制表示的,這樣看其實(shí)byte和int只是長(zhǎng)度不一樣的一個(gè)二進(jìn)制數(shù)而已。需要注意的是在C#中byte和unit都是無(wú)符號(hào)的整數(shù),所以右移并不存在問(wèn)題,左邊位補(bǔ)0就行,但是如果有負(fù)數(shù)的話,符號(hào)位是要補(bǔ)1的。