java浮点数转整数_java.math包下计算浮点数和整数的类的实例

java.math包提供了java中的数学类。包括基本的浮点库、复杂运算以及任意精度的数据运算

提供用于执行任意精度整数算法 (BigInteger) 和任意精度小数算法 (BigDecimal) 的类。BigInteger 除提供任意精度之外,它类似于 Java 的基本整数类型,因此在 BigInteger 上执行的操作不产生溢出,也不会丢失精度。除标准算法操作外,BigInteger 还提供模 (modular) 算法、GCD 计算、基本 (primality) 测试、素数生成、位处理以及一些其他操作。 BigDecimal 提供适用于货币计算和类似计算的任意精度的有符号十进制数字。BigDecimal 允许用户对舍入行为进行完全控制,并允许用户选择所有八个舍入模式。

1. BigDecimal

不可变的、任意精度的有符号十进制数。BigDecimal 由任意精度的整数非标度值 和 32 位的整数标度 (scale) 组成。如果为零或正数,则标度是小数点后的位数。如果为负数,则将该数的非标度值乘以 10 的负 scale 次幂。因此,BigDecimal 表示的数值是 (unscaledValue × 10-scale)。

下面通过一些例子给大家详细介绍下java.math包下计算浮点数和整数的类,一起看看吧

(1)BigIntege:实现任意精度的整数运算。

(2)BigDecimal:实现任意精度的浮点运算。

例如:

使用BigDecimal进行浮点数比较

import java.math.BigDecimal;

public class HelloWorld{

public static void main(String[] args){

BigDecimal a=BigDecimal.valueOf(1.0);

a=a.subtract(BigDecimal.valueOf(0.1)); //subtract:减去

a=a.subtract(BigDecimal.valueOf(0.1));

a=a.subtract(BigDecimal.valueOf(0.1));

a=a.subtract(BigDecimal.valueOf(0.1));

a=a.subtract(BigDecimal.valueOf(0.1));

System.out.println(a); //输出:0.5

System.out.println(1.0-0.1-0.1-0.1-0.1-0.1); //输出:0.5000000000000001

BigDecimal b=BigDecimal.valueOf(0.1);

BigDecimal c=BigDecimal.valueOf(1.0/10.0);

System.out.println(b==c); //false

System.out.println(b.equals(c)); //true

}

}

总结

到此这篇关于java.math包下计算浮点数和整数的类的实例的文章就介绍到这了,更多相关java 计算浮点数和整数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值