C# - 将字节数组转换为十六进制字符串的快速方法

C# - Fast Method to Convert Byte Array to Hex String

我想尽快将字节数组转换为十六进制字符串。

所以通过我之前的问题,我发现 the following code:

private static readonly uint[] _lookup32 = CreateLookup32();

    private static uint[] CreateLookup32()
    {
        var result = new uint[256];
        for (int i = 0; i < 256; i++)
        {
            string s = i.ToString("X2");
            result[i] = ((uint)s[0]) + ((uint)s[1] << 16);
        }
        return result;
    }

    private static string ByteArrayToHexViaLookup32(byte[] bytes)
    {
        var lookup32 = _lookup32;
        var result = new char[bytes.Length * 2];
        for (int i = 0; i < bytes.Length; i++)
        {
            var val = lookup32[bytes[i]];
            result[2 * i] = (char)val;
            result[2 * i + 1] = (char)(val >> 16);
        }
        return new string(result);
    }

这很好用,但问题是输出字符串如下所示:

output: 0F42000AAD24120024
but i need it like this: 0F 42 00 0A AD 24 12 00 24

由于我的编码知识有点像“神秘”的算法,我不知道在哪里以及如何添加代码,所以它会在每 2 个字节之间添加一个空白 space - (Hexoutputstring + " " ) 到它。

我可以遍历字符串并每 2 个字符添加一个空白 space 但这会大大增加它需要给我一个有用结果的时间,因为附加字符串很慢。

有人可以帮我处理上面的代码吗?谢谢你:)

    private static string ByteArrayToHexViaLookup32(byte[] bytes)
    {
        var lookup32 = _lookup32;
        var byteCount = bytes.Length;
        var result = new char[3* byteCount - 1];
        for (int i = 0; i < byteCount; i++)
        {
            var val = lookup32[bytes[i]];
            int index = 3 * i;
            result[index] = (char)val;
            result[index + 1] = (char)(val >> 16);
            if (i < byteCount - 1) result[index + 2] = ' ';
        }
        return new string(result);
    }

如果性能是您主要关注的问题之一,我会这样处理:

private static readonly char[] digits = new char[] { '0', '1', '2', '3', '4', '5', '6', '7', '8', '9', 'A', 'B', 'C', 'D', 'E', 'F' };

private static string ByteArrayToHexViaLookup32(byte[] bytes)
{
    char[] buffer = new char[bytes.Length * 3];
    
    int index = 0;
    for (int i = 0; i < bytes.Length; i++)
    {
        if (index > 0)
            buffer[index++] = ' ';

        buffer[index++] = digits[(bytes[i] >> 4) & 0xf];
        buffer[index++] = digits[bytes[i] & 0xf];
    }
    
    return new string(buffer, 0, index);
}

以下版本不需要任何查找数组,但我不确定它是否一样快。

private static string ByteArrayToHexViaLookup32(byte[] bytes)
{
    char[] buffer = new char[bytes.Length * 3];

    int index = 0;
    for (int i = 0; i < bytes.Length; i++)
    {
        if (index > 0)
            buffer[index++] = ' ';

        buffer[index++] = GetDigit((bytes[i] >> 4) & 0xf);
        buffer[index++] = GetDigit(bytes[i] & 0xf);
    }

    return new string(buffer, 0, index);
}

private char GetDigit(int value)
{
    if (value < 10)
        return (char)('0' + value);
    return (char)('7' + value);
}

两个版本都在字节之间插入一个 space。

private static string ByteArrayToStringHex(byte[] bytes)
    {
        string hexValue = BitConverter.ToString(bytes);
        hexValue = hexValue.Replace("-", " ");

        return hexValue;
    }

我认为它的结果与您想要的值相同