Java精度自动提升和强制类型转换
一丶精度的自动提升
- 整型数据有:byte,short,int,long。都有自己的最大值和最小值,默认值卫0。
demo:定义一个int数据类型的变量
public class HelloWord{//定义一个类
//在类中定义一个方法 ;
public static void main(String[] args){//类中的一个方法(主方法)
//定义一个整型数据
int num = 10;
System.out.println("输出结果为"+num*2.5);
}
}
输出结果为25.0,数字在进行四则运算的时候会自动提升精度,最终计算出来的精度以高精度的为准,这种就叫做精度的自动提升。
二丶数据溢出和扩大数据类型
demo:数据溢出,int类型最大值和最小值分别加1和减1
public class HelloWord{//定义一个类
//在类中定义一个方法 ;
public static void main(String[] args){//类中的一个方法(主方法)
System.out.println("int类型最大值加1:"+(Integer.MAX_VALUE+1));
System.out.println("int类型最小值减1:"+(Integer.MIN_VALUE-1));
}
}
这种叫做数据溢出,最大值和最小值分别加1和减1,最大值变成最小值,最小值变成最大值。如果不让数据溢出那就提升精度
demo:扩大数据类型
默认情况下int类型转换其他类型,如long则在后面加上小写l,如果转换成double则在后面加上d。
public class HelloWord{//定义一个类
//在类中定义一个方法 ;
public static void main(String[] args){//类中的一个方法(主方法)
//int转换成long类型
System.out.println("int类型最大值加1:"+(Integer.MAX_VALUE+1l));
System.out.println("int类型最小值减1:"+(Integer.MIN_VALUE-1l));
}
}
三丶 强制类型转换
public class HelloWord{//定义一个类
//在类中定义一个方法 ;
public static void main(String[] args){//类中的一个方法(主方法)
double num1 = 10.8;
int num2 = (int)num1*10;
System.out.println(num2);
}
}
结果不是108,原因是强制类型转换的时候高精度的数据类型转换为低精度的数据类型会出现精度丢失。