c# – 将2个连续字节的数组更快地转换为整数
作者:互联网
我有一个“巨大”的数据,可能在50到100兆字节之间变化.
我使用filestreamer将这些数据作为字节数组读取.
问题是,我想将所有连续的2个字节转换为整数.
我这样做的方法是循环遍历字节数组,步长为2,然后使用BitConvert进行转换:
_data[i] = BitConverter.ToInt16(soundData[i : i + 2], 0) // Convert 2 bytes into an int and store at i
所以每两个字节变成一个Int16.
然而问题是,这太慢了,对于大约50兆字节的文件,这可能需要20秒!
有没有一种通用的方法可以立即执行此操作,而不是在我的数据数组的每2个字节上调用此函数,这样它就不会那么慢?最好以’安全’的方式,所以没有不安全的代码.
解决方法:
如果字节数组在正确的Endian中,那么只需分配一个Int16数组并使用Buffer.Block copy(air code):
byte[] b = new byte[]{1, 2, 3, 4};
short[] s = new short[2]; // 4 bytes long
Buffer.BlockCopy(b, 0, s, 0, 4);
标签:c,net,mono,boo 来源: https://codeday.me/bug/20190613/1230648.html