您可以编写一个自定义转换运算符:
public struct Test
{
private readonly byte pop;
private readonly byte svp;
private readonly byte uhdp;
private readonly byte mhdp;
// TODO: Properties to return the above
public Test(byte pop, byte svp, byte uhdp, byte mhdp)
{
this.pop = pop;
this.svp = svp;
this.uhdp = uhdp;
this.mhdp = mhdp;
}
public static implicit operator Test(int value)
{
// Working from most significant to least significant bits...
byte mhdp = (byte) ((value >> 0) & 0xff);
byte uhdp = (byte) ((value >> 8) & 0xff);
byte svp = (byte) ((value >> 16) & 0xff);
byte pop = (byte) ((value >> 24) & 0xff);
return new Test(pop, svp, uhdp, mhdp);
}
}
就个人而言,我更喜欢静态FromInt32
方法而不是隐式运算符,但这是你的电话。您很可能不需要& 0xff
转换中的所有部分 - 如果您使用的是 auint
而不是int
. 提取有符号整数的一部分只会让我抽搐,这可能是过度补偿。另一种选择是将 a 强制value
转换uint
为局部变量。