9

我的代码中有 byte[] srno

byte[] srno = new byte[6];

srno[0] = 0xff;
srno[1] = 0x0f;
srno[2] = 0x24;
srno[3] = 0x12;
srno[4] = 0x16;
srno[5] = 0x0a;

现在我想要这个值在 uint 中

uint a = 0xff0f2412160a;

如何转换它?

4

3 回答 3

10

正如@animaonline 建议的那样,您应该使用BitConverter将字节数组转换为uint或*ulong。因此你有 6 个字节,uint对你来说太小了。您应该转换为 ulong*。但转换器需要 8 个字节,因此创建具有所需字节数的新数组:

byte[] value = new byte[8];
Array.Reverse(srno); // otherwise you will have a1612240fff result
Array.Copy(srno, value, 6);
ulong result = BitConverter.ToUInt64(value, 0);
Console.WriteLine("{0:x}", result); // ff0f2412160a
于 2013-02-21T12:27:09.410 回答
1

在 System 命名空间中,您将找到BitConverter库类。您希望静态ToUInt64()函数如下:

var a = BitConvert.ToUInt64(srno, 0);

您需要将数组的大小调整为[8]

MSDN

于 2013-02-21T12:27:40.937 回答
0

每个人似乎都忽略了他预期输出的字节顺序编码。该类BitConverter使用固定编码(通常是 Little-Endian,IIRC)。示例中的输出假定为 Big-Endian。在一个完美的世界里,你只需自己做数学,但使用它比使用Array.Reverse内置BitConverter类更简单。

在我发布之前可能会有一堆答案,所以这里有一段非常快速的不安全代码:

public static unsafe ulong ToULong(byte[] values)
{
    byte* buffer = stackalloc byte[8];
    if (BitConverter.IsLittleEndian)
        Array.Reverse(values);
    System.Runtime.InteropServices.Marshal.Copy(values, 0, (IntPtr)buffer, values.Length);
    return *(ulong*)buffer;
}
于 2013-02-21T12:39:54.927 回答