- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我需要你的帮助。我想使用以下代码,因为我正在开发一个音频工具(仅适用于 .wav 文件),其主要功能是显示信号波形。大端和小端是我无法控制的元素。我认为以下代码解决问题的方式是正确的:- 如果音频文件样本大小为 16 位或 8 位,并且为大端或小端,它会使用 audioData 数组重新排列样本?
如果我的推理是正确的,重新排列是否总是从大端到小端?
是否考虑了计算机架构? (我的意思是,如果我的计算机使用 Little endian,会发生什么?)
谢谢
int[] audioData = null;
if (format.getSampleSizeInBits() == 16) {
int nlengthInSamples = audioBytes.size() / 2;
audioData = new int[nlengthInSamples];
// se Big Endian
if (format.isBigEndian()) {
for (int i = 0; i < nlengthInSamples; i++) {
// MSB calculation - Most Significant Bit
int MSB = (int) audioBytes.get(2 * i);
// LSB calculation - Least Significant Bit
int LSB = (int) audioBytes.get(2 * i + 1);
// (MSB << 8) MSB shift to the left by 8 position
// (255 & LSB) LSB masking so that LSB is <255 or =0
// putting both together
audioData[i] = MSB << 8 | (255 & LSB);
}
} else {
for (int i = 0; i < nlengthInSamples; i++) {
int LSB = (int) audioBytes.get(2 * i);
int MSB = (int) audioBytes.get(2 * i + 1);
audioData[i] = MSB << 8 | (255 & LSB);
}
}
最佳答案
Java 中的所有内容都是 Big Endian,因此您无需担心这一点。您所拥有的内容看起来是正确的(显然,请对其进行测试以确保),但我建议使用以下模式来避免代码复制。
int nlengthInSamples = audioBytes.size() / 2;
audioData = new int[nlengthInSamples];
// default BigEndian
int MSB = (int) audioBytes.get(2 * i);
int LSB = (int) audioBytes.get(2 * i + 1);
// swap for Little Endian
if(!format.isBigEndian()) {
int temp = MSB;
MSB = LSB;
LSB = temp;
}
audioData[i] = MSB << 8 | (255 & LSB);
关于java - 理解大端、小端(再次),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3241434/
我有一条记录: Tconnecting = record var a: int64; b: integer; c: integer; end; 我需要使用UDP协议
我知道,我知道,这听起来很简单,但我很困惑。如果您有以下输入 Data : 1100 0101 1010 1101 并且您想将大端转换为小端,或反之,您认为以下哪项是正确的输出? 1011 0101
我目前正在处理的项目需要与我们不制作的客户端系统交互,因此我们无法控制数据的发送方式。问题是在 C# 中工作,它似乎对 UCS-2 没有任何支持,对 big-endian 的支持也很少。 (据我所知)
我正在编写一个函数,将 ascii 字符串转换为其大端字节序的二进制表示形式。 这是我的代码: int count = 0; for (int i = 0; i = 0; k--) {
我从 MSDN 中找到了以下函数它将 unsigned long 从网络字节转换为主机字节顺序的 unsigned long,即在 little-endian 中定义为: u_long WSAAPI
我正在使用 AES Rijndael 的公共(public)领域引用实现,通常以名称“rijndael-fst-3.0.zip”分发。我打算用它来加密网络数据,我想知道加密结果在大/小端架构上是否会有
我有一个十六进制字符串,其内容为18000000,该字符串采用主机字节顺序(小端),我需要将其转换为网络字节顺序(大端)。生成的十六进制字符串将为 00000018。 总而言之,我需要转换180000
我有一个十六进制字符串,其内容为18000000,该字符串采用主机字节顺序(小端),我需要将其转换为网络字节顺序(大端)。生成的十六进制字符串将为 00000018。 总而言之,我需要转换180000
我正在生成用于模拟网络的单元测试的二进制文件。通过网络发送的一些数据采用 Little Endian 或 Big Endian 模式,我想使用 stub 模拟这些数据并创建二进制文件。 因此,换句话说
这个问题在这里已经有了答案: Endianness Work-around Needed (2 个答案) 关闭 9 年前。 我有一个包含 n 个单精度值的二进制文件。我知道写入数据时使用的格式是大端
我有一个 4 字节编码的日期(大端),我试图从二进制文件中读取它。 我愿意: char date[4]; long seconds; s = read(fd, date, sizeof(char) *
在 Python2.7 中,通过 USB 批量传输,我从相机中获取图像帧: frame = dev.read(0x81, 0x2B6B0, 1000) 我知道一帧是 342x260 = 88920 像
我有一个 byte[4],它包含一个 32 位无符号整数(按大端顺序),我需要将它转换为 long(因为 int 不能保存无符号数)。 此外,我该如何反之(即从包含 32 位无符号整数的 long 到
public static void main(String[] args) { File inFile = null; if (0 0) { getMarker(re
我正在使用 Node.JS。 Node's buffers支持小端 UCS-2,但不支持我需要的大端。我该怎么做? 最佳答案 根据维基百科,UCS-2 should always be big-end
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 7 年前。 Improve this ques
我需要通过串行线路 (RS-232) 从 Arduino 接收十六进制编码的单精度大端浮点值。如何将它们转换为 Python 的 double 大端字节序的 float ? Arduino 发送类似“
类似于如何使用包: N An unsigned long (32-bit) in "network" (big-endian) order. 是否有任何方法可以在 Perl 中以“网络”(大端)顺序
我有一个这样的 C 结构...... struct icmp_prefixopt { u_int8_t icmpopt_type; u_int8_t icm
我正在使用 PHP、fopen、fseek、pack 等创建然后将数据写入文件(一个新的“ESRI Shape 文件”)。文件规范在这里 http://www.esri.com/library/whi
我是一名优秀的程序员,十分优秀!