BigDecimal怎么比较大小?
BigDecimal a = new BigDecimal("1.00");
BigDecmial b = new BigDecimal(1);
想比较一下a和b的大小,一般都会用equals
System.out.println(a.equals(b));
但是输出结果是:fal
原因是:BigDecimal比较时,不仅比较值,而且还比较精度?
if(a.compareTo(b)==0) 结果是true
比较大小可以用 a.compareTo(b)
返回值 -1 小于 0 等于 1 大于
java 中 BigDecimal 怎么与 0 比较
如果不确定 bigDecimal 的范围,可以把 0 转化为 bigDecimal类型的,然后用其 equals方法进行比较
BigDecimal bd1 =... ;//其中的一个bigDecimal对象
BigDecimal bd2 = new BigDecimal(0) //把 0 转为 BigDecimal
就可以用 bd1.CompareTo(bd2) 根据返回值进行比较
在JAVA中怎么比较Double类型数据的大小
你如果是要普通比较直接用数学符号即可,指的在其jvm允许的范围内如果,你是要很准确的精度比较运算,由于精度问题,可能会有误差,建议使用BigDecimal类型!
//普通比较
Doubleobj1=newDouble("0.001");
Doubleobj2=newDouble("0.0011");
obj1.compareTo(obj2);
//精度准确比较
doublea=obj1;
doubleb=obj2;
BigDecimaldata1=newBigDecimal(a);
BigDecimaldata2=newBigDecimal(b);
data1.compareTo(data2);
//该方法两种类都有
publicintcompareTo(BigDecimalval)
/*将此BigDecimal与指定的BigDecimal比较。根据此方法,值相等但具有不同标度的两个BigDecimal对象(如,2.0和2.00)被认为是相等的。相对六个boolean比较运算符(<,==,>,>=,!=,<=)中每一个运算符的各个方法,优先提供此方法。
*参数:val-将此BigDecimal与之比较的BigDecimal。
*返回:当此BigDecimal在数字上小于、等于或大于val时,返回-1、0或1。
*/
BigInteger与BigDecimal
BigInteger - 廖雪峰的网站
在Java中,由CPU原生提供的整型最大范围是64位 long 型整数。使用 long 型整数可以直接通过CPU指令进行计算,速度非常快。
如果我们使用的整数范围超过了 long 型怎么办?这个时候,就只能用软件来模拟一个大整数。 java.math.BigInteger 就是用来表示任意大小的整数。 BigInteger 内部用一个 int[] 数组来模拟一个非常大的整数:
对 BigInteger 做运算的时候,只能使用实例方法,例如,加法运算:
和 long 型整数运算比, BigInteger 不会有范围限制,但缺点是速度比较慢。
也可以把 BigInteger 转换成 long 型:
使用 longValueExact() 方法时,如果超出了 long 型的范围,会抛出 ArithmeticException 。
BigInteger 和 Integer 、 Long 一样,也是不可变类,并且也继承自 Number 类。因为 Number 定义了转换为基本类型的几个方法:
因此,通过上述方法,可以把 BigInteger 转换成基本类型。如果 BigInteger 表示的范围超过了基本类型的范围,转换时将丢失高位信息,即结果不一定是准确的。如果需要准确地转换成基本类型,可以使用 intValueExact() 、 longValueExact() 等方法,在转换时如果超出范围,将直接抛出 ArithmeticException 异常。
如果 BigInteger 的值甚至超过了 float 的最大范围,那么返回的 float 是什么呢?
和 BigInteger 类似, BigDecimal 可以表示一个任意大小且精度完全准确的浮点数。
通过 BigDecimal 的 stripTrailingZeros() 方法,可以将一个 BigDecimal 格式化为一个相等的,但去掉了末尾0的 BigDecimal :
如果一个 BigDecimal 的 scale() 返回负数,例如, -2 ,表示这个数是个整数,并且末尾有2个0。
可以对一个 BigDecimal 设置它的 scale ,如果精度比原始值低,那么按照指定的方法进行四舍五入或者直接截断:
对 BigDecimal 做加、减、乘时,精度不会丢失,但是做除法时,存在无法除尽的情况,这时,就必须指定精度以及如何进行截断:
还可以对 BigDecimal 做除法的同时求余数:
调用 divideAndRemainder() 方法时,返回的数组包含两个 BigDecimal ,分别是商和余数,其中商总是整数,余数不会大于除数。我们可以利用这个方法判断两个 BigDecimal 是否是整数倍数:
在比较两个 BigDecimal 的值是否相等时,要特别注意,使用 equals() 方法不但要求两个 BigDecimal 的值相等,还要求它们的 scale() 相等:
必须使用 compareTo() 方法来比较,它根据两个值的大小分别返回负数、正数和0,分别表示小于、大于和等于。
总是使用 compareTo() 比较两个 BigDecimal 的值,不要使用 equals() !
如果查看 BigDecimal 的源码,可以发现,实际上一个 BigDecimal 是通过一个 BigInteger 和一个 scale 来表示的,即 BigInteger 表示一个完整的整数,而 scale 表示小数位数:
BigDecimal 也是从 Number 继承的,也是不可变对象。
java中BigDecimal怎么与0比较?
标准做法x0dx0aintr=big_decimal.compareTo(BigDecimal.Zero);//和0,Zero比较x0dx0aif(r==0)//等于x0dx0aif(r==1)//大于x0dx0aif(r==-1)//小于x0dx0ax0dx0a或者x0dx0aif(big_decimal.equals(BigDecimal.Zero))//是否等于0
c语言中double类型值的大小比较
由于double浮点数的精度问题,所以在比较大小的时候,不能像int整数型那样,直接if(a==b),if(a<b),if(a>b)。
要使用一个精度EPS:
const double EPS = 1e-6; //一般这样子就够,但有时具体题目要考虑是否要更小的 ;
if(fabs(a-b) < EPS) //判断是否相等 ;
if(a > b+EPS) // 判断a是否大于b,因为大的肯定大,所以即使你小的加上,还是会更大 。
扩展资料
JAVA double类型比较大小
@org.junit.Test
public void Test(){
BigDecimal big = new BigDecimal(1);
BigDecimal Graphicprice = new BigDecimal(0.01);//图文价格
BigDecimal Speechprice = new BigDecimal(0.02);//语音价格
BigDecimal Videoprice = new BigDecimal(1);//视频价格
System.out.println(Graphicprice + " " + Speechprice +" " + Videoprice);
if(Graphicprice.compareTo(big)<0 || Graphicprice.compareTo(big)==0 ||
Speechprice.compareTo(big)<0 || Speechprice.compareTo(big)==0 ||
Videoprice.compareTo(big)<0 || Videoprice.compareTo(big)==0){
System.out.println("ok");
}
}