位运算 - 多个整形变量的合并和拆分
最近看见一个用short型存放两个byte型的例子。学习了一下。
需要注意,这么做的时候最好是无符号整形,有符号需要补码。
使用ushort存放两个byte类型:
void Execute() { byte a = 255; byte b = 255; ushort c = a; c = (ushort)(a | b << 8); b = (byte)(c & 0xff); a = (byte)(c >> 8); Debug.Log("a: " + a + " b: " + b); }
一个字节是8位,short类型是两个字节。一个byte是一个字节。
首先,位移运算优先于或运算。b先向左移了8位,然后和a做或运算,和a+b是一样的效果。
这样就合并到c中。
取出的时候,先和0xff(全部位为1)进行与运算,把c的高位清零。低位就是b。
取a的时候就比较简单了,直接向右移8位。
注:0xF = 1111
那么再举一反三,把4个byte放入int类型当中:
void Execute2() { byte a = 251; byte b = 252; byte c = 253; byte d = 254; uint e = a; e <<= 8; e |= b; e <<= 8; e |= c; e <<= 8; e |= d; d = (byte)(e & 0xffffff); c = (byte)((e >> 8) & 0xffff); b = (byte)((e >> 16) & 0xff); a = (byte)(e >> 24); Debug.Log("a: " + a + " b: " + b + " c: " + c + " d: " + d); }
以上用法,在读文件头或者特定字节时非常有用,就可以直接取得想要的信息做比较了。并且相对于4次或者8次比较操作,位运算合并后只需要进行一次。