我有一个整数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
因为你将该字节“或”放回:
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)
| 归档时间: |
|
| 查看次数: |
81 次 |
| 最近记录: |