[英]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);
但是,结果是一样的,当我加 1,这个字节。 有人可以解释原因并告诉我如何从这个字节中减去-1吗?
更新:因此,我想要的结果是以下二进制数:
00000101 00000110 00000100 00000101
因为你是“或” - 回到那个字节:
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
;
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
使用“联合” - 因此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.你或者用原始值得到它,你得到0000111,就像你加了1一样。
作为你的问题的一个方面,你应该掩盖你操纵的位的区域:
int West =(u&0x00FFFFFF)| ((((u&0xFF000000)>> 24) - 1)<< 24);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.