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

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

  举例

  浮点数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);
}
}

  小结

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

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

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

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

最新文章

  1. android 多个notifycation向同一个Actiivity传递不同数据
  2. TP验证
  3. Python字符串的修改以及传参
  4. Hibernate笔记——表的的4种继承关系
  5. Firefox 设置技巧
  6. C#中byte[]与string的转换
  7. 最接近原生APP体验的高性能前端框架-MUI
  8. Linux中FTP远程传输,SSH远程连接,以及SCP远程拷贝
  9. [Android]使用Spring for Android改善数据交互流程
  10. 2019.04.26 mongaodb
  11. 2019-1-24 Spark 学习 --总体架构
  12. React Native ——入门环境搭配以及简单实例
  13. GlusterFS实战
  14. 安装JIRA
  15. 『科学计算_理论』优化算法:梯度下降法&amp;牛顿法
  16. linux基础命令学习(二)文件和目录操作
  17. c# 值类型与引用类型(转)
  18. chromedriver Capabilities &amp; ChromeOptions
  19. Hystrix参数说明
  20. python多线程安全local()

热门文章

  1. Flume高级之自定义MySQLSource
  2. Git学习笔记--实践(三)
  3. lis框架各种方法的使用
  4. npm run dev 报错 iview TypeError [ERR_INVALID_CALLBACK]: Callback must be a function
  5. Support Vector Machines
  6. solidworks 学习 (一)
  7. JS开发——文件夹的上传和下载
  8. 深入解析pure virtual function call
  9. hive select 出现问题 SemanticException
  10. RESTFull开发风格