# Bigdecimal用法

Bigdecimal用法

// int 转 BigDecimal

int value = 150;

BigDecimal num = new BigDecimal(value);

// BigDecimal 转 int

BigDecimal num2 = new BigDecimal(150);

int value2 = num2 .intValue();

// long 转 BigDecimal

long value3 = 12L;

BigDecimal num3 = new BigDecimal(value3);

// BigDecimal 转 long

BigDecimal num4 = new BigDecimal(12);

long value4 = num4.longValue();

// 第一种方法:public BigDecimal(double val)

// 存在精度问题
double val5 = 12.23;

BigDecimal num5 = new BigDecimal(val5);

// 第二种方法:public static BigDecimal valueOf(double val)

double value6 = 12.23;

BigDecimal num6 = BigDecimal.valueOf(value6);

// 第三种方法:Double.toString(double d)

double value7 = 12.23;

BigDecimal num7 = new BigDecimal(Double.toString(value7));

BigDecimal num8 = new BigDecimal("12.23");

double value8 = num8.doubleValue();

// 第一种方法:Float.toString(float f)

float value9 = 12.23f;

BigDecimal num9 = new BigDecimal(Float.toString(value9));

// 第二种方法:public static BigDecimal valueOf(double val)

// 会损失精度

float value10 = 12.23f;

BigDecimal num10 = BigDecimal.valueOf(value10);

BigDecimal num11 = new BigDecimal("12.23");

float value11 = num11.floatValue();

// 加法

BigDecimal result = num.add(num2);

// 减法

BigDecimal result = num.subtract(num2);

// 乘法

BigDecimal result = num.add(num2);

// 除法

BigDecimal result = num.add(num2);

//绝对值

BigDecimal result4 = num3.abs();

//取余数 remainder

BigDecimal b1 = new BigDecimal(v1); //被除数

BigDecimal b2 = new BigDecimal(v2); //除数

b1.remainder(b2).setScale(scale, BigDecimal.ROUND_HALF_UP);

//转负数

b1.negate() ;

// 设置精度的方法
// scale 是保留小数位数;
//roundingMode 为小数模式

ROUND_CEILING //向正无穷方向舍入
ROUND_DOWN //向零方向舍入
ROUND_FLOOR //向负无穷方向舍入
ROUND_HALF_DOWN //向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,向下舍入, 例如1.55 保留一位小数结果为1.5
ROUND_HALF_EVEN //向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,如果保留位数是奇数,使用ROUND_HALF_UP,如果是偶数,使用ROUND_HALF_DOWN
ROUND_HALF_UP //向(距离)最近的一边舍入,除非两边(的距离)是相等,如果是这样,向上舍入, 1.55保留一位小数结果为1.6
ROUND_UNNECESSARY //计算结果是精确的,不需要舍入模式
ROUND_UP //向远离0的方向舍入

// 除法 - 对计算结果设置精度

BigDecimal result = num.divide(num2, 1, BigDecimal.ROUND_HALF_UP);

// 对一个 BigDecimal 对象设置精度

BigDecimal result = num.setScale(1, BigDecimal.ROUND_HALF_UP);

Bigdecimal比较:

num3.compareTo(num4) :返回结果为0,代表相等,返回结果为1,代表大于,返回结果-1,代表小于。

add(BigDecimal): BigDecimal对象中的值相加,返回BigDecimal对象
subtract(BigDecimal): BigDecimal对象中的值相减,返回BigDecimal对象
multiply(BigDecimal): BigDecimal对象中的值相乘,返回BigDecimal对象
divide(BigDecimal): BigDecimal对象中的值相除,返回BigDecimal对象
toString(): 将BigDecimal对象中的值转换成字符串
doubleValue(): 将BigDecimal对象中的值转换成双精度数
floatValue(): 将BigDecimal对象中的值转换成单精度数
longValue(): 将BigDecimal对象中的值转换成长整数
intValue(): 将BigDecimal对象中的值转换成整数
a.max (b) :比较取最大值
a.min(b):比较取最小值a.abs() 取最绝对值
valueOf(double):返回BigDecimal对象
toPlainString() //返回不带指数字段的BigDecimal的字符串表示形式,非科学计数。
NumberFormat类的常用方法:

format(long number) 格式化数值,返回String

format(double number)

parse(String str) 将特定格式的String转化为Number类型(数值型)

NumberFormat currency = NumberFormat.getCurrencyInstance(); //建立货币格式化引用

NumberFormat percent = NumberFormat.getPercentInstance(); //建立百分比格式化引用

percent.setMaximumFractionDigits(3); //百分比小数点最多3位

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 一、BigDecimal简介 float和double类型的主要设计目的是为了科学计算和工程计算。它们执行二进制浮...
    行者_shi阅读 6,952评论 0 1
  • 一、简介 Java在java.math包中提供的API类BigDecimal,用来对超过16位有效位的数进行精确的...
    刘奎永6330阅读 427评论 1 1
  • 一.bigdecimal 基本算法 加,减,乘,除,BigDecimal类提供了相应的成员方法。 1 public...
    sugarsun阅读 2,070评论 0 0
  • 一、引言 float和double类型的主要设计目标是为了科学计算和工程计算。他们执行二进制浮点运算,这是为了在广...
    AC编程阅读 279评论 0 1
  • /*返回double类型 ; 能进行四舍五入*/ public void method1() { double f...
    小鱼儿_f32a阅读 792评论 0 0

友情链接更多精彩内容