在从短数组转换为字节数组时,我在网上找到了以下解决方案,但无法理解所涉及的逻辑.
//buffer is an array of bytes, bytes[] buffer[position] = (byte)(sample & 0xff); buffer[position+1] = (byte)((sample >> 8) & 0xff);
有人可以告诉我为什么0xff(256)是对样本的短信?
这段代码可能来自C代码(或者由不解析Java的C程序员和erickson编写).这是因为在Java中,从具有更多信息的类型到具有较少信息的类型的转换将丢弃较高阶位,因此在两种情况下都不需要&0xff.
短路有16位,两个字节.所以它需要在字节数组中占用两个槽,因为如果我们只是将一个short转换成一个字节,那么一个字节就会丢失.
所以,你所拥有的代码
1110001100001111 sample 0000000011111111 0xff 0000000000001111 sample & 0xff => first byte`
然后,替换样本以获取第二个字节
0000000011100011 sample >> 8 0000000011111111 0xff 0000000011100011 (sample >> 8 ) & 0xff => second byte
正如下面的erickson所示,这可以写得更好(希望它会很快就会出现).