Java浮点类数字运算方式

 更新时间:2024年10月24日 14:24:47   作者:知楠行易  
在进行浮点数的加减运算时,直接使用+和-可能会引入精度误差,为了比较浮点数,可以使用Double的compareTo()方法,或者通过定义一个容差值(Epsilon)来判断两个浮点数是否相等,此外,Double.compare()方法也能比较两个double值

浮点数运算可以直接使用 + 和 - 运算符进行加减操作,但可能会有一定的问题:

  • 精度问题
  • 比较问题
  • 累积误差

一、比较大小

比较问题:由于精度问题,直接比较两个浮点数是否相等可能会出错。

1.1 使用 compareTo() 方法

对于 Double 的包装类,可以使用 compareTo() 方法来比较两个 Double 对象的大小。

这个方法同样返回一个整数,表示比较的结果

Double a = 0.1 + 0.2;
Double b = 0.3;

int result = a.compareTo(b);
if (result < 0) {
    System.out.println("a is less than b");
} else if (result > 0) {
    System.out.println("a is greater than b");
} else {
    System.out.println("a is equal to b");
}

1.2 使用容差值(Epsilon)比较

double a = 0.1 + 0.2;
double b = 0.3;
double epsilon = 0.000001; // 容差值

if (Math.abs(a - b) < epsilon) {
    System.out.println("a and b are approximately equal");
} else if (a < b) {
    System.out.println("a is less than b");
} else {
    System.out.println("a is greater than b");
}

1.3 使用 Double.compare()

Double.compare() 方法是一个静态方法,可以用来比较两个 double 值。

这个方法会返回一个整数,表示第一个值与第二个值的关系:

  • 如果第一个值小于第二个值,则返回负数。
  • 如果第一个值等于第二个值,则返回零。
  • 如果第一个值大于第二个值,则返回正数。
double a = 0.1 + 0.2;
double b = 0.3;

int result = Double.compare(a, b);
if (result < 0) {
    System.out.println("a is less than b");
} else if (result > 0) {
    System.out.println("a is greater than b");
} else {
    System.out.println("a is equal to b");
}

二、求和运算

  • 精度问题:浮点数在计算机中是以近似值存储的,因此在进行加减运算时可能会出现精度损失。
  • 累积误差:在进行多次浮点数运算时,误差可能会累积,导致结果偏差更大。

2.1 使用 BigDecimal 精确求和

// 创建 BigDecimal 对象
BigDecimal num1 = new BigDecimal("0.1");
BigDecimal num2 = new BigDecimal("0.2");

// 精确求和
BigDecimal sum = num1.add(num2);
sum.doubleValue()

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • SpringBoot中YAML语法及几个注意点说明

    SpringBoot中YAML语法及几个注意点说明

    这篇文章主要介绍了SpringBoot中YAML语法及几个注意点说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-02-02
  • 深入浅出Java mvc_动力节点Java学院整理

    深入浅出Java mvc_动力节点Java学院整理

    这篇文章主要为大家详细介绍了MVC的基础知识,MVC是一个框架模式,它强制性的使应用程序的输入、处理和输出分开,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-08-08
  • 关于springboot 中使用httpclient或RestTemplate做MultipartFile文件跨服务传输的问题

    关于springboot 中使用httpclient或RestTemplate做MultipartFile文件跨服务传输

    这篇文章主要介绍了关于springboot 中使用httpclient或RestTemplate做MultipartFile文件跨服务传输的问题,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2021-01-01
  • RestTemplate发送form-data请求上传rul资源文件及对象参数方式

    RestTemplate发送form-data请求上传rul资源文件及对象参数方式

    这篇文章主要介绍了RestTemplate发送form-data请求上传rul资源文件及对象参数方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2024-01-01
  • Springcloud sentinel安装和使用方法解析

    Springcloud sentinel安装和使用方法解析

    这篇文章主要介绍了Springcloud sentinel安装和使用方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-12-12
  • SpringBoot整合mybatis/mybatis-plus实现数据持久化的操作

    SpringBoot整合mybatis/mybatis-plus实现数据持久化的操作

    这篇文章主要介绍了SpringBoot整合mybatis/mybatis-plus实现数据持久化,本节内容我们介绍了数据持久化的相关操作,并且是基础传统的关系型数据库——mysql,需要的朋友可以参考下
    2022-10-10
  • Spring使用AspectJ注解和XML配置实现AOP

    Spring使用AspectJ注解和XML配置实现AOP

    这篇文章主要介绍了Spring使用AspectJ注解和XML配置实现AOP的相关资料,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2016-10-10
  • 详解java中List中set方法和add方法的区别

    详解java中List中set方法和add方法的区别

    本文主要介绍了详解java中List中set方法和add方法的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-08-08
  • Java连接ftp服务器实例代码

    Java连接ftp服务器实例代码

    这篇文章主要介绍了Java连接ftp服务器实例代码 的相关资料,需要的朋友可以参考下
    2015-12-12
  • java中类和对象的详细介绍

    java中类和对象的详细介绍

    这篇文章主要给大家介绍了关于java中类和对象的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2021-03-03

最新评论