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

Rut*_*itz 5 c# byte bit-shift

我有一个整数u = 101057541.

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

现在,我将每个字节视为一个单独的小数(在这种情况下为6,6,4,5).我想从第一个字节中减去-1,结果是6-1 = 5.我尝试按如下方式执行此操作:

int West = u | (((u>>24) - 1) << 24);
Run Code Online (Sandbox Code Playgroud)

但是,结果是一样的,当我加入 1到该字节.有人可以解释原因并告诉我如何从这个字节中减去-1吗?

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

00000101 00000110 00000100 00000101

Mar*_*ell 4

因为你将该字节“或”放回:

 u | (((u>>24) - 1) << 24);
Run Code Online (Sandbox Code Playgroud)

应该

 (u & mask) | (((u>>24) - 1) << 24);
Run Code Online (Sandbox Code Playgroud)

mask除了你正在玩的字节之外的所有东西都在哪里。

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

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

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);
Run Code Online (Sandbox Code Playgroud)

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

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

和:

[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;
}
Run Code Online (Sandbox Code Playgroud)