我想用 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;
}