这段代码没有错,可能是你对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.
String ss = "0.01";
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
类型后该对象表示的数值。
你是怎么得到的byte数组呢?