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

最近看见一个用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 @   HONT  阅读(847)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
点击右上角即可分享
微信分享提示
回到顶部