位运算 - 多个整形变量的合并和拆分

最近看见一个用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次比较操作,位运算合并后只需要进行一次。

posted @ 2017-01-06 20:06  HONT  阅读(840)  评论(0编辑  收藏  举报