0

我想用 UTF-16 编码字符串中的字节填充缓冲区的一部分,而不分配中间字节数组(即不调用Encoding.Unicode.GetBytes(str)

假设我知道一个字符串只包含ASCII字符,下面的代码安全吗?

        for (var i = 0; i < str.Length; i++)
        {
            var code = char.ConvertToUtf32(str, i);

            var high = (byte) (code & 0xFF);
            var low = (byte) ((code >> 8) & 0xFF);

            //k is the offset where we insert bytes of the UTF-16 encoded string

            buffer[i*2 + k] = high;
            buffer[i*2 + k + 1] = low;
        }
4

1 回答 1

1

有一个超载可以满足GetBytes您的需求。

Encoding.Unicode.GetBytes(str, 0, str.Length, buffer, k);
// or, if you need to do something more complicated inside the `for` loop
for (var i = 0; i < str.Length; i++)
{
    Encoding.Unicode.GetBytes(str, i, 1, buffer, i*2 + k);
}
于 2013-10-23T17:44:04.980 回答