java.math包下计算浮点数和整数的类的实例
2020-03-19 12:07
936 查看
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 计算浮点数和整数内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
您可能感兴趣的文章:
相关文章推荐
- 第二章 Java浮点数精确计算
- Java计算几何图形面积的实例代码
- Java实例4 - 快速计算二进制数中1的个数(Fast Bit Counting)
- Java循环-输入一个整数,计算它各位上数字的和。(注意:是任意位的整数)
- java正则表达式验证整数、浮点数和日期(转)
- Java.math.BigDecimal.subtract()方法实例
- Java的浮点数和整数的进制转换
- java基本类型(数值范围):浮点的底层表示定义,float计算快一些
- Java大整数实现计算catalan数
- JAVA计算大整数
- 大整数计算类(浮点类未完成)
- 【Java编程】Java中的大整数计算
- Java浮点数float,bigdecimal和double精确计算的精度误差问题总结
- 在Java中实现浮点数的精确计算
- Java模拟计算机的整数乘积计算功能示例
- Java判断字符串是否是整数或者浮点数
- shell实例浅谈之检测整数、浮点数和日期数的合法性
- 利用commons-math-1.1进行java数值计算
- java浮点类型float精度与Double精度范围实例使用说明
- Java中使用BigDecimal进行浮点数精确计算、超大整数、浮点数等计算,没有数位限制