java浮点数计算_Java之浮点数运算

浮点数在计算机中由于二进制表示的限制,无法精确表示某些数值,如0.1,导致运算存在误差。比较浮点数时,不应直接用相等判断,而应比较它们差值的绝对值是否小于一个很小的阈值。整数在与浮点数运算时会提升为浮点数,浮点数除以0会得到特殊值NaN、Infinity和-Infinity。强制转换浮点数为整数会丢弃小数部分,超出整型范围则返回整型最大值。
摘要由CSDN通过智能技术生成

浮点数运算和整数运算相比,只能进行加减乘除这些数值运算,不能做位运算和移位运算。

在计算机中,浮点数虽然表示的范围很大,但是浮点数有个非常重要的特点,就是浮点数常常无法精确表示

举例

浮点数0.1在计算机中就无法精确表示,因为十进制的0.1换算成二进制是一个无限循环小数,很显然,无论使用float还是double,都只能存储一个0.1的近似值。但是,0.5这个浮点数又可以精确地表示。因为浮点数常常无法精确表示,因此,浮点数运算会产生误差:

public class Main {

public static void main(String[] args) {

double x=1.0 / 10;

double y=1-9.0 / 10;

System.out.println(x);

System.out.println(y);

}

}

运行结果

0.1

0.09999999999999998

由于浮点数存在运算误差,所以比较两个浮点数是否相等常常会出现错误的结果。正确的比较方法是判断两个浮点数之差的绝对值是否小于一个很小的数:

public class Main {

public static void main(String[] args) {

double x=1.0 / 10;

double y=1-9.0 / 10;

System.out.println(x);

System.out.println(y);

double r=Math.abs(x-y);

if(r<0.00001) {

System.out.println("true");

}

else {

System.out.println("false");

}

}

}

浮点数在内存的表示方法和整数比更加复杂。Java的浮点数完全遵循IEEE-754标准,这也是绝大多数计算机平台都支持的浮点数标准表示方法。

类型提升

如果参与计算的两个数其中一个是整型,那么整型可以自动提升到浮点型

public class Main {

public static void main(String[] args) {

int n=5;

double d=1.2+24.0/n;

System.out.println(d); //6.0

}

}

需要特别注意,在一个复杂的四则运算中,两个整数的运算不会出现自动提升的情况。例如:

double d = 1.2 + 24 / 5; // 5.2

计算结果为4.2,原因是编译器计算24/5这个子表达式时,按两个整数进行运算,结果为4,而不是按浮点运算4.8

溢出

整数运算在除数为0时会报错,而浮点数运算在除数为0时,不会报错,但会返回几个特殊值:

NaN表示Not a Number

Infinity表示无穷大

-Infinity表示负无穷大

例如

double d1 = 0.0 / 0; // NaN

double d2 = 1.0 / 0; // Infinity

double d3 = -1.0 / 0; // -Infinity

这三种特殊值使用较少

强制转型

可以将浮点数强制转型为整数,在转型时,浮点数的小数部分会被丢弃。如果转型后超过了整型能表示的最大范围,将返回整型最大值

public class Main {

public static void main(String[] args) {

int n1=(int) 12.3; //12

System.out.println(n1);

int n2=(int) 12.7; //12

System.out.println(n2);

int n3=(int) -12.7; //-12

System.out.println(n3);

int n4=(int) 9999999991.11; //2147483647

System.out.println(n4);

}

}

小结

浮点数无法精确表示,并且浮点数的运算结果可能有误差。

比较两个浮点数通常比较他们的绝对值之差是否小于一个特定值。

整型和浮点型运算时,整型会自动提升为浮点型。

可以将浮点型强制转换为整型,但超出范围后将始终返回整型的最大值。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值