- 浏览: 162639 次
文章分类
最新评论
-
sydneytsao2:
gfs球棒gsd
Java设计模式——六大原则 -
涛涛饭:
memoryisking 写道可以看看这篇文章,构建一个简单的 ...
Java线程池使用说明 -
a492846462:
Java线程池使用说明 -
sprita1:
资源很好很强大,对楼主膜拜中.....
Java线程池使用说明 -
memoryisking:
可以看看这篇文章,构建一个简单的线程池:http://www. ...
Java线程池使用说明
原文地址 http://lavasoft.blog.51cto.com/62575/228705
从Java4到Java5,Java对BigInteger、BigDecimal两个类功能一直再做扩展与改进。主要原因是这两个数据类型很重要,在高精度的计算中全靠这两个数据类型了。BigInteger和BigDecimal分别表示任意精度的整数与浮点数。
本文中不在追溯各个版本的变化,只看Java5中两个类的使用。
一、java.math.BigInteger
不可变的任意精度的整数。 此类的用法比较简单些,也不存在舍入等操作。
二、java.math.BigDecimal
不可变的、任意精度的有符号十进制数。与之相关的还有两个类:
java.math.MathContext:
该对象是封装上下文设置的不可变对象,它描述数字运算符的某些规则,如数据的精度,舍入方式等。
java.math.RoundingMode:这是一种枚举类型,定义了很多常用的数据舍入方式。
这个类用起来还是很比较复杂的,原因在于舍入模式,数据运算规则太多太多,不是数学专业出身的人看着中文API都难以理解,这些规则在实际中使用的时候在翻阅都来得及。
从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
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包:
- 类
- BigDecimal
- BigInteger
- MathContext
- 枚举
- RoundingMode
- 掌握了构造方式,和常见的数学运算,在开发中一般够用了。
发表评论
-
设置session失效的几种方法
2013-12-12 09:30 595设置session失效的几种 ... -
Java性能基础-Java堆内存
2013-01-25 15:25 1087导读:对于程序员来说,知道堆空间,设置堆空间,处理堆空间的o ... -
Collection框架
2013-01-25 15:13 1073Collection框架 集合框架 ... -
为什么匿名内部类只能访问其所在方法中的final变量
2013-01-25 14:48 822(1).内部类是外部类的一个成员,就像外部类的成员方法一样,所 ... -
Tomcat目录及server.xml详解
2012-09-11 13:23 852本文参考自:Tomcat全 ... -
java获得项目绝对路径
2012-09-05 11:16 5174在jsp和class文件中调用的相对路径不同。在 ... -
HttpURLConnection用法详解
2012-09-03 11:35 954HttpURLConnectio ... -
Java简单问题
2012-08-14 22:56 9081.HashMap和HashTable区别 Has ... -
FilenameFilter的几种基本用法
2012-08-13 10:41 770现在假设我们想观看 ... -
Java中的finalize
2012-08-02 13:14 856Java中finalize() ... -
编写一个程序,将d:\java目录下的所有.java文件复制到d:\jad目录下,并将原来文件的扩展名从.java改为.jad
2012-08-02 11:54 2802编写一个程序,将d:\java目录下的所有.java文件复制到 ... -
问题列表
2012-07-27 17:17 3391.描述一下JVM加载class文件的原理机制? 2.试举例说 ... -
死锁是什么
2012-07-27 13:10 824在并发程序设计中,死 ... -
Java内存分配:Java堆.栈和常量池
2012-07-26 17:31 713Java堆.栈和常量池 博 ... -
Java集合总结
2012-07-25 17:11 1227在Java中使用Set,可以方 ... -
String.replaceAll() 正则表达式
2012-07-19 15:46 1103最近项目中出现了一个 ... -
问题列表
2012-07-19 15:45 706问题1:list中是string,最快的排序 List li ... -
WebService基本原理
2012-07-19 10:17 699Web 服务有两层含义:1、是指封装成单个实体并发布到网络上的 ... -
重写equal 的同时为什么必须重写hashcode?
2012-07-18 17:09 1157分类: java 2011-10-21 11:33 1 ... -
web.xml
2012-07-18 08:39 698web.xml 中的listener、 filter、serv ...
相关推荐
BigInteger BigDecimal 使用
BigInteger.java BigDecimal.java 文件 源代码
BigInteger (大整数类) 使用时导包:java.math.BigInteger 作用:可以使用BigInteger操作大整数,也可以转换进制。如果在操作的时候一个整型数据已经超过了整数的最大类型长度long的话,则此数据就无法装入,所以...
BigInteger、BigDecimal 和 BigRational 这些是多精度BigInteger 、 BigDecimal和BigRational类型的实现,从头开始构建。 大整数 BigInteger是一个多精度整数。 它的大小仅受可用内存的限制。 BigInteger是为易用性...
biginteger源码用于 JavaScript 的 BigDecimal BigDecimal for Javascript是不可变、任意精度、有符号十进制数的纯 Javascript 实现。 BigDecimal 支持任意精度的十进制数学。 在有限的时间内,我们将免费提供...
红鳞 用于 JavaScript/ClojureScript 的 BigInteger、BigDecimal 和 Ratio 库。 目前在阿尔法
主要介绍了Java Bigdecimal使用原理详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
Java中BigInteger的数学运算,BigDecimal 加减乘除运算,Java在java.math包中提供的API类BigDecimal,用来对超过16位有效位的数进行精确的运算。双精度浮点型变量double可以处理16位有效数。在实际应用中,需要对更大...
java.math.BigDecimal 操作类,包含加减乘除、String型加减乘除精度格式化转换计算等
主要介绍了Java BigInteger类,BigDecimal类,Date类,DateFormat类及Calendar类用法,结合实例形式详细分析了Java使用BigInteger类,BigDecimal类,Date类,DateFormat类及Calendar类进行数值运算与日期运算相关操作...
在 Java 编程中,经常需要对数字类型的数据进行转换。其中,BigDecimal 是一种高精度的十进制浮点数类型,适合处理大数值计算。在一些需求中,我们可能需要将 ...此时,可以使用 BigInteger 类型来表示大整数。
用java写的BigInteger,主要是实现一个内库
单个封装中具有任意精度的所有数量的所有格式,包括所有三角函数,对数函数,算术函数,矩阵函数等。
使用BigInteger类实现,实现了RSA的加解密
BigInteger不是基本数据类型之一,它其实更像String,是Java里的一个类,然而它的初始化方式却没有String那么方便可以直接赋值,而是跟其他自定义的类一样,要调用它的构造器进行初始化。
JavaScript支持大整数,页面需要进入BigInteger.js。才能使用
BigInteger, JS插件脚本
C#写的BigInteger,我也是下载的,在这个和大家分享吧
bigNumber 这是Java的API,用于处理非常大的数字并对其进行计算。 基本上,它结合了Java的BigInteger和BigDecimal。 有关更多信息,请访问:
kmulti-bignumber为BigDecimal和BigInteger类型提供了多平台expect声明和actual实现。 下载 repositories { maven { url "https://dl.bintray.com/kmulti/kmulti-bignumber" } } 每个Kotlin模块分别使用以下依赖...