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语言中 数组的构造方式使用的就是“小端方式”
∴我将我的实现方法表达出来了