参考 http://lavasoft.blog.51cto.com/62575/228705/

从Java4到Java5,Java对BigInteger、BigDecimal两个类功能一直再做扩展与改进。主要原因是这两个数据类型很重要,在高精度的计算中全靠这两个数据类型了。BigInteger和BigDecimal分别表示任意精度的整数与浮点数。
 
本文中不在追溯各个版本的变化,只看Java5中两个类的使用。
 
一、java.math.BigInteger
 
不可变的任意精度的整数。 此类的用法比较简单些,也不存在舍入等操作。

 package lavasoft; 

 import java.math.BigInteger;
import java.util.Random; /**
* 测试BigInteger
*
* @author leizhimin 2009-11-17 12:49:41
*/
public class TestBigInteger {
public static void main(String[] args) {
System.out.println("-------------------构造BigInteger---------------------");
//通过byte数组来创建BigInteger
BigInteger bi1 = new BigInteger(new byte[]{1, 1});
System.out.println("bi1=" + bi1.toString());
//创建带符号的BigInteger
BigInteger bi2 = new BigInteger(-1, new byte[]{1, 1});
System.out.println("bi2=" + bi2.toString());
//创建带符号的BigInteger随机数
BigInteger bi3 = new BigInteger(128, 20, new Random());
System.out.println("bi3=" + bi3.toString());
//通过10进制字符串创建带符号的BigInteger
BigInteger bi4 = new BigInteger("12342342342342123423423412341");
System.out.println("bi4=" + bi4.toString());
//通过10进制字符串创建带符号的BigInteger
BigInteger bi5 = new BigInteger("88888888888888888888888888888", Character.digit('a', 33));
System.out.println("bi5=" + bi5.toString());
System.out.println("BigInteger的常量:");
System.out.println("BigInteger.ZERO=" + BigInteger.ZERO);
System.out.println("BigInteger.ONE=" + BigInteger.ONE);
System.out.println("BigInteger.TEN=" + BigInteger.TEN); System.out.println("-------------------使用BigInteger---------------------");
System.out.println("bi1的相反数=" + bi1.negate());
System.out.println("bi1的相反数=" + bi1.negate());
System.out.println("bi1+bi2=" + bi1.add(bi2));
System.out.println("bi1-bi2=" + bi1.subtract(bi2));
System.out.println("bi1*bi2=" + bi1.multiply(bi2));
System.out.println("bi1/bi2=" + bi1.divide(bi2));
System.out.println("bi1的10次方=" + bi1.pow(10));
System.out.println("bi1的10次方=" + bi1.pow(1));
BigInteger[] bx = bi4.divideAndRemainder(bi1);
System.out.println(">>>:bx[0]=" + bx[0] + ",bx[1]=" + bx[1]);
System.out.println("bi2的绝对值=" + bi2.abs());
}
}
运行结果:
-------------------构造BigInteger--------------------- 
bi1=257 
bi2=-257 
bi3=175952079487573456985958549621373190227 
bi4=12342342342342123423423412341 
bi5=88888888888888888888888888888 
BigInteger的常量: 
BigInteger.ZERO=0 
BigInteger.ONE=1 
BigInteger.TEN=10 
-------------------使用BigInteger--------------------- 
bi1的相反数=-257 
bi1的相反数=-257 
bi1+bi2=0 
bi1-bi2=514 
bi1*bi2=-66049 
bi1/bi2=-1 
bi1的10次方=1256988294225653106805249 
bi1的10次方=257 
>>>:bx[0]=48024678374872075577523005,bx[1]=56 
bi2的绝对值=257

Process finished with exit code 0

 
二、java.math.BigDecimal
 
不可变的、任意精度的有符号十进制数。与之相关的还有两个类:
java.math.MathContext:

该对象是封装上下文设置的不可变对象,它描述数字运算符的某些规则,如数据的精度,舍入方式等。
java.math.RoundingMode:这是一种枚举类型,定义了很多常用的数据舍入方式。
 
这个类用起来还是很比较复杂的,原因在于舍入模式,数据运算规则太多太多,不是数学专业出身的人看着中文API都难以理解,这些规则在实际中使用的时候在翻阅都来得及。
 
 package lavasoft; 

 import java.math.BigDecimal;
import java.math.MathContext;
import java.math.RoundingMode; /**
* 测试BigDecimal
*
* @author leizhimin 2009-11-17 12:50:03
*/
public class TestBigDecimal { public static void main(String[] args) {
System.out.println("------------构造BigDecimal-------------");
//从char[]数组来创建BigDecimal
BigDecimal bd1 = new BigDecimal("123456789.123456888".toCharArray(), 4, 12);
System.out.println("bd1=" + bd1);
//从char[]数组来创建BigDecimal
BigDecimal bd2 = new BigDecimal("123456789.123456111133333213".toCharArray(), 4, 18, MathContext.DECIMAL128);
System.out.println("bd2=" + bd2);
//从字符串创建BigDecimal
BigDecimal bd3 = new BigDecimal("123456789.123456111133333213");
System.out.println("bd3=" + bd3);
//从字符串创建BigDecimal,3是有效数字个数
BigDecimal bd4 = new BigDecimal("88.456", new MathContext(3, RoundingMode.UP));
System.out.println("bd4=" + bd4);
System.out.println("------------使用BigDecimal-------------");
System.out.println("bd1+bd2=" + bd1.add(bd2));
System.out.println("bd1+bd2=" + bd1.add(bd2, new MathContext(24, RoundingMode.UP)));
System.out.println("bd1-bd2=" + bd1.subtract(bd2).toPlainString());
System.out.println("bd1-bd2=" + bd1.subtract(bd2, new MathContext(24, RoundingMode.UP)).toPlainString());
System.out.println("bd1*bd2=" + bd1.multiply(bd2));
System.out.println("bd1*bd2=" + bd1.multiply(bd2, new MathContext(24, RoundingMode.UP)));
System.out.println("bd1/bd4=" + bd1.divideToIntegralValue(bd4));
System.out.println("bd1/bd4=" + bd1.divideToIntegralValue(bd4, new MathContext(24, RoundingMode.UP)));
System.out.println("bd1末位数据精度=" + bd1.ulp());
System.out.println("bd2末位数据精度=" + bd2.ulp());
System.out.println("bd2末位数据精度=" + bd2.ulp().toPlainString());
System.out.println("bd1符号:" + bd1.signum());
System.out.println("bd4的标度:" + bd4.scale());
}
}
 
运行结果:
------------构造BigDecimal------------- 
bd1=56789.123456 
bd2=56789.123456111133 
bd3=123456789.123456111133333213 
bd4=88.5 
------------使用BigDecimal------------- 
bd1+bd2=113578.246912111133 
bd1+bd2=113578.246912111133 
bd1-bd2=-0.000000111133 
bd1-bd2=-0.000000111133 
bd1*bd2=3225004542.907120529593035648 
bd1*bd2=3225004542.90712052959304 
bd1/bd4=641.00000 
bd1/bd4=641.00000 
bd1末位数据精度=0.000001 
bd2末位数据精度=1E-12 
bd2末位数据精度=0.000000000001 
bd1符号:1 
bd4的标度:1

Process finished with exit code 0

 
最后回顾下本文所涉及的API范围:
 
java.math包:

掌握了构造方式,和常见的数学运算,在开发中一般够用了。

【转】BigInteger、BigDecimal详解的更多相关文章

  1. 【java提高】(19)---BigDecimal详解和精度问题

    BigDecimal详解和精度问题 一.背景 在实际开发中,对于 不需要任何准确计算精度的属性可以直接使用float或double,但是如果需要精确计算结果,则必须使用BigDecimal,例如价格. ...

  2. Java BigDecimal详解,提供了丰富的四舍五入规则

    java.math.BigDecimal类提供用于算术,刻度操作,舍入,比较,哈希算法和格式转换操作. toString()方法提供BigDecimal的规范表示.它使用户可以完全控制舍入行为. 提供 ...

  3. Java之BigDecimal详解

    一.BigDecimal概述 ​ Java在java.math包中提供的API类BigDecimal,用来对超过16位有效位的数进行精确的运算.双精度浮点型变量double可以处理16位有效数,但在实 ...

  4. BigInteger 与 BigDecimal区别,及BigDecimal详解

    一般来说,BigInteger用的不是很多,BigDecimal用的稍微多一点,就比如说JDBC中,如果一个字段的数据库类型是Number, 那么getObject().getClass()的结果是j ...

  5. Java BigDecimal详解

    借用<Effactive Java>这本书中的话,float和double类型的主要设计目标是为了科学计算和工程计算.他们执行二进制浮点运算,这是为了在广域数值范围上提供 较为精确的快速近 ...

  6. BigDecimal 使用方法详解

    BigDecimal 使用方法详解 博客分类: java基础 bigdecimalmultiplyadddivide  BigDecimal 由任意精度的整数非标度值 和 32 位的整数标度 (sca ...

  7. BigDecimal用法详解(转)

    BigDecimal用法详解    http://www.cnblogs.com/linjiqin/p/3413894.html 一.简介Java在java.math包中提供的API类BigDecim ...

  8. BigDecimal的用法详解(保留两位小数,四舍五入,数字格式化,科学计数法转数字,数字里的逗号处理)

    转自:https://blog.csdn.net/ochangwen/article/details/51531866 一.简介 Java在java.math包中提供的API类BigDecimal,用 ...

  9. BigDecimal 用法详解

    BigDecimal简介 BigDecimal用法: BigDecimal的构造方法 BigDecimal常用方法描述 BigDecimal比较 BigDecimal总结 BigDecimal简介 J ...

随机推荐

  1. [Golang] 从零開始写Socket Server(2): 自己定义通讯协议

    在上一章我们做出来一个最基础的demo后,已经能够初步实现Server和Client之间的信息交流了~ 这一章我会介绍一下怎么在Server和Client之间实现一个简单的通讯协议.从而增强整个信息交 ...

  2. UVA1406 - A Sequence of Numbers(树状数组)

    UVA1406 - A Sequence of Numbers(树状数组) 题目链接 题目大意: 给定N个数字.给两种操作:C x: 把这N个数字都加上x. Q x:查询这N个数里面有多少个数字和2^ ...

  3. MySQL的备份与恢复具体解释

    MySQL数据备份 在mySQL里面,有逻辑备份和物理备份.逻辑备份最大长处是对于各种存储引擎,都能够使用相同的方法来备份. 而物理备份则不同.不同的存储引擎有着不同的备份方法. 逻辑备份与恢复 备份 ...

  4. rsync的几则tips(渗透技巧)

    转自91ri 关于rsync rsync(remote synchronize)——Linux下实现远程同步功能的软件,能同步更新两处计算机的文件及目录.在同步文件时,可以保持源文件的权限.时间.软硬 ...

  5. F - 概率(经典问题)

    Description Sometimes some mathematical results are hard to believe. One of the common problems is t ...

  6. 【Excle数据透视表】如何移动数据透视表的位置

    数据透视表创建完成了,现在需要将它移动到D5位置,如何移动呢? 解决办法 通过"移动数据透视表"功能实现数据透视表的位置移动 步骤1 单击数据透视表任意单元格→数据透视表工具→分析 ...

  7. php的strip_tags,htmlspecialchars,htmlentities,stripslashes,addslashes解释

    php函数蛮多的,要完整的每个函数都理解深刻是个挺有挑战性的事情. strip_tags,htmlspecialchars,htmlentities,stripslashes,addslashes这几 ...

  8. 将C#文档注释生成.chm帮助文档(转)

    由于最近需要把以前的一个项目写一个文档,但一时又不知道写成怎样的,又恰好发现了可以生成chm的工具,于是乎我就研究了下,感觉还不错,所以也给大家分享下.好了,不多废话,下面就来实现一下吧. 生成前的准 ...

  9. Bootstrap学习速查表(三) 表单

    表单中常见的元素主要包括:文本输入框.下拉选择框.单选按钮.复选按钮.文本域和按钮等. 一.基础表单 1.初始化:对于基础表单,Bootstrap并未对其做太多的定制性效果设计,仅仅对表单内的fiel ...

  10. com.opensymphony.xwork2.ognl.OgnlValueStack - Error setting expression 'customer.applyRate' with value '[Ljava.lang.String;@7d3fae2c'

    出错的3个最可能的原因:我是第二种错误 1.action配置错误 <action name="doCreateMeetingInfo" class="meeting ...