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

最近看见一个用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位。

 

 

那么再举一反三,把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);
}

 

 

以上用法,在读文件头或者特定字节时非常有用,你可以直接取得想要的信息做比较了。

转载于:https://www.cnblogs.com/hont/p/6257590.html

在 51 单片机中,通过位运算进行字节拆分合并的方法如下: 1. 字节拆分:通过移位和按位与(&)运算将一个字节的高位和低位分离出来。 ```c unsigned char byte = 0xB6; // 待拆分的字节 unsigned char high = byte >> 4; // 高四位 unsigned char low = byte & 0x0F; // 低四位 ``` 2. 字节合并:通过移位和按位或(|)运算将两个字节合并为一个字节。 ```c unsigned char high = 0x0B; // 高四位 unsigned char low = 0x06; // 低四位 unsigned char byte = (high << 4) | low; // 合并为一个字节 ``` 下面是一个完整的例程,演示了如何将一个 16 位的整数拆分为两个 8 位的字节,以及如何将两个 8 位的字节合并为一个 16 位的整数。 ```c #include <reg52.h> typedef unsigned char uint8_t; typedef unsigned int uint16_t; // 将 16 位的整数拆分为两个 8 位的字节 void split_uint16(uint16_t val, uint8_t *high, uint8_t *low) { *high = (uint8_t)(val >> 8); // 高八位 *low = (uint8_t)(val & 0xFF); // 低八位 } // 将两个 8 位的字节合并为一个 16 位的整数 uint16_t merge_uint8(uint8_t high, uint8_t low) { return ((uint16_t)high << 8) | (uint16_t)low; } void main() { uint16_t val = 0xABCD; uint8_t high, low; split_uint16(val, &high, &low); printf("val = %04X, high = %02X, low = %02X\n", val, high, low); val = merge_uint8(high, low); printf("val = %04X\n", val); while (1); } ``` 输出结果为: ``` val = ABCD, high = AB, low = CD val = ABCD ``` 其中,split_uint16() 函数将 16 位的整数拆分为两个 8 位的字节,merge_uint8() 函数将两个 8 位的字节合并为一个 16 位的整数。在 main() 函数中,先将一个 16 位的整数拆分为两个 8 位的字节,然后再将这两个字节合并为一个 16 位的整数,输出结果证明了拆分合并操作的正确性。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值