如何在 C# 中对整数的特定字节执行 -1?

How to do -1 on a specific byte of an integer in C#?

我有一个整数 u=101057541。

二进制,这等于:00000110 00000110 00000100 00000101

现在,我将每个字节视为一个单独的小数(因此在本例中为 6、6、4、5)。 我想从第一个字节中减去-1,得到 6-1=5。 我尝试按如下方式执行此操作:

int West = u | (((u>>24) - 1) << 24);

但是结果和我ADD1到这个字节是一样的。有人可以解释为什么并告诉我如何从这个字节中减去 -1 吗?

更新: 因此,我想要的结果是以下二进制数:

00000101 00000110 00000100 00000101

因为您正在 "or"-ing 返回那个字节:

 u | (((u>>24) - 1) << 24);

应该是

 (u & mask) | (((u>>24) - 1) << 24);

其中 mask 是除您正在玩的字节之外的所有内容。

您可能会发现不安全的代码更容易:

int i = 101057541;
byte* b = (byte*)&i;
b[3]--; // note CPU endianness is important here
Console.WriteLine(i);

如果您使用的是所有最新位,则无需 unsafe 使用 "spans" 也可以做同样的事情;

int i = 101057541;
var bytes = MemoryMarshal.Cast<int, byte>(MemoryMarshal.CreateSpan(ref i, 1));
bytes[3]--; // note CPU endianness is important here
Console.WriteLine(i);

或者您可以通过具有显式布局的 struct 使用 "union" - 因此 4 个字节重叠 1 个 int:

var x = new Int32Bytes();
x.Value = 101057541;
x.Byte3--; // note CPU endianness is important here
Console.WriteLine(x.Value);

与:

[StructLayout(LayoutKind.Explicit)]
struct Int32Bytes
{
    [FieldOffset(0)]
    public int Value;
    [FieldOffset(0)]
    public byte Byte0;
    [FieldOffset(1)]
    public byte Byte1;
    [FieldOffset(2)]
    public byte Byte2;
    [FieldOffset(3)]
    public byte Byte3;
}

当您从 00000110 中减去 1 时,结果为 00000101。您将其与原始值进行 OR 运算,得到 0000111,这与您加 1 时的结果相同。

作为您问题的单行线,您应该屏蔽掉您正在操作的位区域。:

int 西 = (u & 0x00FFFFFF) | ((((u & 0xFF000000)>>24) - 1) << 24);