Java中如何将以byte数组给出的数据转换为double数组形式

1 致谢

感谢陈玮学长的代码 
由于学习了他的代码 我才最终得出了正确的结论

2 问题描述

今天编程的时候遇到1个问题 需要从一个二进制文件中读取double[]的数据
我们使用的编程语言是Java语言 
经过查阅资料之后发现:Java似乎不能直接通过double[]的指针直接读取数据
∴如果我们想通过使用类似C语言的进行指针操作完成数据读写应该是行不通的 
需要转换其它思路实现这个目标
首先我们来明确一下可以做到的事情 
首先我们把所有的数组数据读入到了一个byte[]数组中 这件事情是可以做到的
代码如下:
File sourceFile = new File(source);
FileInputStream stream = new FileInputStream(source);
DataInputStream dis = new DataInputStream(stream);

for (int i = 0; i < bufferSize; i++) {
	dis.read(buffer, 0, doubleSize);
}
使用DataInputStream的read()方法就可以实现
然后需要我们自己实现一个byte[]转换为double的转换函数
再利用循环一个个放入double[]数组中就可以了
然后经过查阅资料 又获得1个有效信息
就是long类型可以使用函数Double.longBitsToDouble()直接转换为double
所以最终剩下的问题就是如何将byte[]转换为double
总结一下转换函数的需求描述:
输入 —— 长度为8的byte[]
输出 —— 1个long数据

3 算法设计

使用位运算实现
一共有8个byte数据 分别是8个字节数据构成1个long数据
对于每个byte数据 
1.使用“<<”运算将字节移动到相应的位置
2.用“& 0xFF”进行“位清理”
(注意位清理的时候  0xFF同样需要进行相应的移位操作
具体的实现可以参考我的“代码实现”)
3.用“|”操作进行合并
4.重复上述过程

4 代码实现

	/**
	 * 将一个8位字节数组转换为双精度浮点数。<br>
	 * 注意,函数中不会对字节数组长度进行判断,请自行保证传入参数的正确性。
	 * 
	 * @param b
	 *            字节数组
	 * @return 双精度浮点数
	 */
	public static double bytesToDouble(byte[] b) {
		return Double.longBitsToDouble(bytesToLong(b));
	}

	/**
	 * 将一个8位字节数组转换为长整数。<br>
	 * 注意,函数中不会对字节数组长度进行判断,请自行保证传入参数的正确性。
	 * 
	 * @param b
	 *            字节数组
	 * @return 长整数
	 */
	public static long bytesToLong(byte[] b) {
		int doubleSize = 8;
		long l = 0;
		for (int i = 0; i < doubleSize; i++) {
			// 如果不强制转换为long,那么默认会当作int,导致最高32位丢失
			l |= ((long) b[i] << (8 * i)) & (0xFFL << (8 * i));
		}

		return l;
	}

以上是代码实现 大家可以看看

5 后记

其实百度一下 网上还是有很多byte[]数组转double的方法
但是我还是把自己的方法记录了下来 
因为已经养成了记录的习惯
而且我的方法和网上的方法还是有一些不同 
第一 我是用循环的方法实现的
代码具有更高的可读性
第二 大家课可以看看我的代码实现
是“数据低字节保存在内存的高地址中” ∴使用的是小端方式
而网上的方法大多讲的是“大端方式” 但我觉得这是不够的
因为在C语言中 数组的构造方式使用的就是“小端方式
∴我将我的实现方法表达出来了 


你可能感兴趣的:(java,音频编码)