1

我是 Java 新手,正在研究字节数组。

我有一个在数据库中创建的 Blob,它包含一个 double 和 float 值。现在我必须将它读入一个字节数组,并且应该能够分别获得浮点数和双精度数。

我将 blob 信息读入字节数组,如下所示:

FileInputStream fin = new FileInputStream(file);

byte[] fileContent = new byte[(int)file.length()];

fin.read(fileContent);

并读取字节数组,如

for(int i = 0; i < fileContent.length; i++)

{

  System.out.println("bit " + i + "= " + fileContent[i]);

  }

这是给字节

   bit 0= -57
   bit 1= -16
   bit 2= -90
   bit 3= -109
   bit 4= 66
   bit 5= -90
   bit 6= 116
   bit 7= -25
   bit 8= -100
4

2 回答 2

0

您可以使用longBitsToDoubleintBitsToFloat来转换long(64 位)或int(32 位)。但是,您必须注意浮点数是否具有与 Java 匹配的二进制布局;并且您已经注意以正确的顺序组装从 blob 读取的字节。(使用<<运算符)。

于 2013-10-23T15:17:22.403 回答
0

我认为最简单且最不容易出错的方法是使用 ByteBuffer。这是一个包含两个测试用例的示例,第一个创建一个二进制文件,第二个读取它。请注意,您可以将字节编码设置为小端或大端。

import org.junit.Test;
import java.io.*;
import java.nio.ByteBuffer;
import java.nio.ByteOrder;

public class ByteStreamWriteRead {
  @Test
  public void write() throws IOException {
    ByteBuffer buffer = ByteBuffer.allocate(32);
    buffer.order(ByteOrder.BIG_ENDIAN);

    System.out.println("Putting: " + Math.PI + ", " + (float) Math.PI);
    buffer.putDouble(Math.PI);
    buffer.putFloat((float) Math.PI);

    File file = new File("C:/tmp/file.bin");
    file.createNewFile();

    try (FileOutputStream fos = new FileOutputStream(file)) {
      fos.write(buffer.array(), 0, buffer.position());
    }
  }

  @Test
  public void read() throws IOException {
    File file = new File("C:/tmp/file.bin");
    byte[] a = new byte[32];
    if (file.exists()) {
      try (FileInputStream fis = new FileInputStream(file)) {
        fis.read(a);
      }

      ByteBuffer buffer = ByteBuffer.wrap(a);
      buffer.order(ByteOrder.BIG_ENDIAN);

      System.out.println(buffer.getDouble());
      System.out.println(buffer.getFloat());
    } else {
      System.out.println("File doesn't exist");
    }
  }
}

请注意:上面的示例并未显示读取或写入文件的最有效方法。您应该使用缓冲的读取器/写入器并重用 ByteBuffer 一次读取一大块字节。那是特定于应用程序的。上面的示例仅显示了使用 ByteBuffer 和正确字节编码的逻辑。

于 2013-10-23T15:44:17.760 回答