求JAVA中BYTE[] 转 FLOAT 代码
大家好,我是菜鸟一个。想尝试把一个BYTE[4]转为一个FLOAT数据类型。下面代码是我从网上搜的,但是结果貌似不是很正确:publicstaticfloatgetFlo...
大家好,我是菜鸟一个。想尝试把一个BYTE[4]转为一个FLOAT数据类型。下面代码是我从网上搜的,但是结果貌似不是很正确:
public static float getFloat(byte[] b) {
// 4 bytes
int accum = 0;
for ( int shiftBy = 0; shiftBy < 4; shiftBy++ ) {
accum |= (b[shiftBy] & 0xff) << shiftBy * 8;
}
return Float.intBitsToFloat(accum);
}
求另一代码
通过随即文件读取的,但是这个文件是用C++写的 直接READFLOAT()等等读取的值都是错误的 展开
public static float getFloat(byte[] b) {
// 4 bytes
int accum = 0;
for ( int shiftBy = 0; shiftBy < 4; shiftBy++ ) {
accum |= (b[shiftBy] & 0xff) << shiftBy * 8;
}
return Float.intBitsToFloat(accum);
}
求另一代码
通过随即文件读取的,但是这个文件是用C++写的 直接READFLOAT()等等读取的值都是错误的 展开
4个回答
展开全部
这段代码没有错,可能是你对float理解错了。
关于float的一些资料:
float规格化表示
java中的浮点数采用的事IEEE Standard 754 Floating Point Numbers标准,该标准的规范可以参考http://blog.csdn.net/treeroot/articles/94752.aspx.
float占用4个字节,和int是一样,也就是32bit.
第1个bit表示符号,0表示正数,1表示负数,这个很好理解,不用多管.
第2-9个bit表示指数,一共8为(可以表示0-255),这里的底数是2,为了同时表示正数和负数,这里要减去127的偏移量.这样的话范围就是(-127到128),另外全0和全1作为特殊处理,所以直接表示-126到127.
剩下的23位表示小数部分,这里23位表示了24位的数字,因为有一个默认的前导1(只有二进制才有这个特性).
最后结果是:(-1)^(sign) * 1.f * 2^(exponent)
这里:sign是符号位,f是23bit的小数部分,exponent是指数部分,最后表示范围是(因为正负数是对称的,这里只关心正数)
2^(-126) ~~ 2(1-2^(-24)) * 2^127
这个还不是float的取值范围,因为标准中还规定了非规格化表示法,另外还有一些特殊规定.
非规格化表示:
当指数部分全0而且小数部分不全0时表示的是非规格化的浮点数,因为这里默认没有前导1,而是0.
关于float的一些资料:
float规格化表示
java中的浮点数采用的事IEEE Standard 754 Floating Point Numbers标准,该标准的规范可以参考http://blog.csdn.net/treeroot/articles/94752.aspx.
float占用4个字节,和int是一样,也就是32bit.
第1个bit表示符号,0表示正数,1表示负数,这个很好理解,不用多管.
第2-9个bit表示指数,一共8为(可以表示0-255),这里的底数是2,为了同时表示正数和负数,这里要减去127的偏移量.这样的话范围就是(-127到128),另外全0和全1作为特殊处理,所以直接表示-126到127.
剩下的23位表示小数部分,这里23位表示了24位的数字,因为有一个默认的前导1(只有二进制才有这个特性).
最后结果是:(-1)^(sign) * 1.f * 2^(exponent)
这里:sign是符号位,f是23bit的小数部分,exponent是指数部分,最后表示范围是(因为正负数是对称的,这里只关心正数)
2^(-126) ~~ 2(1-2^(-24)) * 2^127
这个还不是float的取值范围,因为标准中还规定了非规格化表示法,另外还有一些特殊规定.
非规格化表示:
当指数部分全0而且小数部分不全0时表示的是非规格化的浮点数,因为这里默认没有前导1,而是0.
展开全部
String ss = "0.01";
byte[] b= ss.getBytes();
float f = Float.parseFloat(new String(b));
System.out.println(f);
byte[] b= ss.getBytes();
float f = Float.parseFloat(new String(b));
System.out.println(f);
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
【【【使用方法,你的byte.floatvalue()和byte.shortvalue()】】】
floatvalue
public
float
floatvalue()作为一个
float
返回此
byte
的值。
指定者:
类
number
中的
floatvalue
返回:
转换为
float
类型后该对象表示的数值。
------------------------------
shortvalue
public
short
shortvalue()作为一个
short
返回此
byte
的值。
覆盖:
类
number
中的
shortvalue
返回:
转换为
short
类型后该对象表示的数值。
floatvalue
public
float
floatvalue()作为一个
float
返回此
byte
的值。
指定者:
类
number
中的
floatvalue
返回:
转换为
float
类型后该对象表示的数值。
------------------------------
shortvalue
public
short
shortvalue()作为一个
short
返回此
byte
的值。
覆盖:
类
number
中的
shortvalue
返回:
转换为
short
类型后该对象表示的数值。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你是怎么得到的byte数组呢?
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询