public class Main {
public static void main(String args[]) {
float a = 1, b = 2.0f, h = 1F;
float area = ((a+b)*h/2.0);
System.out.println(area);
}}
public class Main {
public static void main(String args[]) {
float a = 1, b = 2.0f, h = 1F;
float area = ((a+b)*h/2.0);
System.out.println(area);
}}
在java里面,浮点数默认是double,((a+b)*h/2.0)这么写的话,产生的结果是double,我们知道double是高精度,float是低精度,高精度是不能赋值给低精度的。除非强转,就像这样(float) ((a + b) * h / 2.0)
((a+b)*h/2),这样写的话,除以2的话,上面的变量都是float,产生的结果是float,一个float变量除以int型的变量2,产生的结果是float,是对的