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整合kaptcha生成验证码功能

    springboot整合kaptcha生成验证码功能

    这篇文章主要介绍了springboot整合kaptcha生成验证码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-10-10
  • 浅谈synchronized方法对非synchronized方法的影响

    浅谈synchronized方法对非synchronized方法的影响

    下面小编就为大家带来一篇浅谈synchronized方法对非synchronized方法的影响。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-10-10
  • Java中的事件处理机制详细解读

    Java中的事件处理机制详细解读

    这篇文章主要介绍了Java中的事件处理机制详细解读,ava事件处理是采取"委派事件模型",当事件发生时,产生事件的对象会把此"信息"传递给"事件的监听者"处理,需要的朋友可以参考下
    2024-01-01
  • java super关键字知识点详解

    java super关键字知识点详解

    在本篇文章里小编给大家整理的是一篇关于java super关键字知识点详解内容,有兴趣的朋友们可以参考下。
    2021-01-01
  • Java日常记录之查看Maven本地仓库的位置

    Java日常记录之查看Maven本地仓库的位置

    这篇文章主要介绍了Maven本地仓库的用途和配置方法,它提供了查看、修改本地仓库路径的步骤,包括检查settings.xml文件、使用Maven命令和查看输出日志,需要的朋友可以参考下
    2024-12-12
  • Spring Boot 底层原理基础深度解析

    Spring Boot 底层原理基础深度解析

    这篇文章主要介绍了Spring Boot 底层原理基础,包括底层注解@Configuration,底层注解@Import及底层注解@Conditional的相关知识,本文结合示例代码给大家介绍的非常详细,需要的朋友可以参考下
    2022-04-04
  • Java中内核线程理论及实例详解

    Java中内核线程理论及实例详解

    在本篇文章里小编给大家整理了一篇关于Java中内核线程理论及实例详解内容,有兴趣的朋友们可以学习下。
    2021-03-03
  • Java 实战项目锤炼之嘟嘟健身房管理系统的实现流程

    Java 实战项目锤炼之嘟嘟健身房管理系统的实现流程

    读万卷书不如行万里路,只学书上的理论是远远不够的,只有在实战中才能获得能力的提升,本篇文章手把手带你用java+SSM+jsp+mysql+maven实现一个健身房管理系统,大家可以在过程中查缺补漏,提升水平
    2021-11-11
  • List转换成Map工具类的简单实例

    List转换成Map工具类的简单实例

    下面小编就为大家带来一篇List转换成Map工具类的简单实例。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-01-01
  • Spring项目中Ordered接口的应用之全局过滤器(GlobalFilter)的顺序控制

    Spring项目中Ordered接口的应用之全局过滤器(GlobalFilter)的顺序控制

    在Spring框架,尤其是Spring Cloud Gateway或Spring WebFlux项目中,Ordered接口扮演着重要的角色,特别是在实现全局过滤器(GlobalFilter)时,用于控制过滤器执行的优先级,下面将介绍如何在Spring项目中使用Ordered接口来管理Global Filter的执行顺序,需要的朋友可以参考下
    2024-06-06

最新评论