byte b[]={0x41,(byte) 0xc8,0,0};
//方法1 流输入,适用于 ME / SE 环境
//默认大端数,如果小端数,可以先翻转数组
DataInputStream dis=new DataInputStream(new ByteArrayInputStream(b));
float f=dis.readFloat();
dis.clo se ();
System.out.println(f);
//方法2 缓存输入,适用于SE/ EE 环境
ByteBuffer buf=ByteBuffer.allocateDirect(4); //无额外内存的直接缓存
//buf=buf.order(ByteOrder.LITTLE_ENDIAN);//默认大端,小端用这行
buf.put(b);
buf.rewind();
float f2=buf.getFloat();
System.out.println(f2);
//方法1 流输入,适用于 ME / SE 环境
//默认大端数,如果小端数,可以先翻转数组
DataInputStream dis=new DataInputStream(new ByteArrayInputStream(b));
float f=dis.readFloat();
dis.clo se ();
System.out.println(f);
//方法2 缓存输入,适用于SE/ EE 环境
ByteBuffer buf=ByteBuffer.allocateDirect(4); //无额外内存的直接缓存
//buf=buf.order(ByteOrder.LITTLE_ENDIAN);//默认大端,小端用这行
buf.put(b);
buf.rewind();
float f2=buf.getFloat();
System.out.println(f2);
都将显示读出来的浮点数25.0
实验确认应用环境适合方法2。
本文介绍两种从字节数组中读取浮点数的方法:一是使用DataInputStream配合ByteArrayInputStream;二是利用ByteBuffer直接操作。这两种方法均能正确解析出25.0这一浮点数值。
2578

被折叠的 条评论
为什么被折叠?



