class test{
public static void main(String[] args){
float x = 12.3F;
long y = 100L;
y = (long)x;
x = y;
}
}
写java的时候,遇到long跟float的转换会比较少见,但遇到的时候可能会遇到一个小坑,那就是明明float是4个字节的,而long是8个字节的,可是范围确实float大。也就是说float转long需要强制类型转换,而long转float可以直接隐式转换。
这个情况的原因在于,float占的4个字节,也就是32位二进制中,1位是符号位,23位是尾数位,剩下的8位是指数位,8位代表0~255,根据IEEE 754规定,0代表0,255代表无穷大,剩下1~254,每个减去127,代表-126~127这个指数范围,也就是说float的幂级数大致范围是2的-126次幂到127次幂之间,而long是8个字节,也就是64位,除去符号位,范围在只有2的63次幂,远远小于float。