目录
一、BigDecimal(高精度的浮点数运算)
1.1、ROUND_UP
1.2、ROUND_DOWN
1.3、ROUND_CEILING
1.4、ROUND_FLOOR
1.5、ROUND_HALF_UP
1.6、ROUND_HALF_DOWN
1.7、ROUND_HALF_EVEN 银行家舍入法
1.8、ROUND_UNNECESSARY
二、Biginteger(高精度的整数运算)
三、Math.random()方法
四、Math类(精度要求比较高的运算不适合)
五、数字格式化
一、BigDecimal(高精度的浮点数运算)
- 用来对超过16位有效位的数进行精确的运算。
- 用于商业计算
- BigDecimal.ROUND_HALF_XXX的各种用法
- 在银行、帐户、计费等领域,BigDecimal提供了精确的数值计算。其中8种舍入方式值得掌握。
1.1、ROUND_UP
- 舍入远离零的舍入模式。
- 在丢弃非零部分之前始终增加数字(始终对非零舍弃部分前面的数字加1)。
- 注意:此舍入模式始终不会减少计算值的大小。
1.2、ROUND_DOWN
- 接近零的舍入模式。
- 在丢弃某部分之前始终不增加数字(从不对舍弃部分前面的数字加1,即截短)。
- 注意:此舍入模式始终不会增加计算值的大小。
1.3、ROUND_CEILING
- 接近正无穷大的舍入模式。
- 如果 BigDecimal 为正,则舍入行为与 ROUND_UP 相同;
- 如果为负,则舍入行为与 ROUND_DOWN 相同。
- 注意:此舍入模式始终不会减少计算值。
1.4、ROUND_FLOOR
- 接近负无穷大的舍入模式。
- 如果 BigDecimal 为正,则舍入行为与 ROUND_DOWN 相同;
- 如果为负,则舍入行为与 ROUND_UP 相同。
- 注意:此舍入模式始终不会增加计算值。
1.5、ROUND_HALF_UP
- 向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为向上舍入的舍入模式。
- 如果舍弃部分 >= 0.5,则舍入行为与 ROUND_UP 相同;否则舍入行为与 ROUND_DOWN 相同。
- 注意:这是我们大多数人在小学时就学过的舍入模式(四舍五入)。
1.6、ROUND_HALF_DOWN
- 向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则为上舍入的舍入模式。
- 如果舍弃部分 > 0.5,则舍入行为与 ROUND_UP 相同;否则舍入行为与 ROUND_DOWN 相同(五舍六入)。
1.7、ROUND_HALF_EVEN 银行家舍入法
- 向“最接近的”数字舍入,如果与两个相邻数字的距离相等,则向相邻的偶数舍入。
- 如果舍弃部分左边的数字为奇数,则舍入行为与 ROUND_HALF_UP 相同;
- 如果为偶数,则舍入行为与 ROUND_HALF_DOWN 相同。
- 注意:在重复进行一系列计算时,此舍入模式可以将累加错误减到最小。
- 此舍入模式也称为“银行家舍入法”,主要在美国使用。四舍六入,五分两种情况。
- 如果前一位为奇数,则入位,否则舍去。
以下例子为保留小数点1位,那么这种舍入方式下的结果。
1.15>1.2 1.25>1.2
1.8、ROUND_UNNECESSARY
- 断言请求的操作具有精确的结果,因此不需要舍入。
- 如果对获得精确结果的操作指定此舍入模式,则抛出ArithmeticException。
public BigDecimal div(double value1, double value2) {
return div(value1, value2, location); // 调用自定义除法方法
}
// 定义除法方法,参数分别为除数与被除数以及商小数点后的位数
public BigDecimal div(double value1, double value2, int b) {
if (b < 0) {
System.out.println("b值必须大于等于0");
}
BigDecimal b1 = new BigDecimal(Double.toString(value1));
BigDecimal b2 = new BigDecimal(Double.toString(value2));
// 调用除法方法,商小数点后保留b位,并将结果进行四舍五入操作
return b1.divide(b2, b, BigDecimal.ROUND_HALF_UP);
}
public static void main(String[] args) {
cc b = new cc();
System.out.println("两个数字相加结果:" + b.add(-7.5, 8.9));
System.out.println("两个数字相减结果:" + b.sub(-7.5, 8.9));
System.out.println("两个数字相乘结果:" + b.mul(-7.5, 8.9));
System.out.println("两个数字相除结果,结果小数后保留10位:"+b.div(10, 2));
System.out.println("两个数字相除,保留小数后5位:"+b.div(-7.5,8.9, 5));
}
public static BigDecimal div(double value1,double value2,int b,int r){
if(b<0){
System.out.println("b值必须大于等于0");
}
BigDecimal b1=new BigDecimal(Double.toString(value1));
BigDecimal b2=new BigDecimal(Double.toString(value2));
return b1.divide(b2,b,r);
}
public static void main(String[] args) {
// TODO 自动生成方法存根
UseCase u=new UseCase();
System.out.println(u.div(-7.5,8.9,5,BigDecimal.ROUND_CEILING));
System.out.println(u.div(-7.5,8.9,5,BigDecimal.ROUND_DOWN));
System.out.println(u.div(-7.5,8.9,5,BigDecimal.ROUND_FLOOR));
System.out.println(u.div(-7.5,8.9,5,BigDecimal.ROUND_HALF_DOWN));
System.out.println(u.div(-7.5,8.9,5,BigDecimal.ROUND_HALF_EVEN));
System.out.println(u.div(-7.5,8.9,5,BigDecimal.ROUND_HALF_UP));
System.out.println(u.div(-7.5,8.9,5,BigDecimal.ROUND_UP));
}
二、Biginteger(高精度的整数运算)
- 在BigInteger类中封装了多种操作,除了基本的加减乘除操作外,还提供了绝对值,相反数,最大公约数以及判断是否为 质数等的操作。
- 使用BigInteger类时,可实例化一个BigInteger对象,并自动调用相应的构造函数。
- BigInteger类具有很多构造函数,最直接的一种方式是参数以字符串的形式代表要处理的数字。
BigInteger bigInstance = new BigInteger("4"); // 实例化一个大数字
// 取该大数字加2的操作
System.out.println("加法操作:" + bigInstance.add(new BigInteger("2")));
// 取该大数字减2的操作
System.out.println("减法操作:"
+ bigInstance.subtract(new BigInteger("2")));
// 取该大数字乘以2的操作
System.out.println("乘法操作:"
+ bigInstance.multiply(new BigInteger("2")));
// 取该大数字除以2的操作
System.out.println("除法操作:"
+ bigInstance.divide(new BigInteger("2")));
// 取该大数字除以3的商
System.out.println("取商:"
+ bigInstance.divideAndRemainder(new BigInteger("3"))[0]);
// 取该大数字除以3的余数
System.out.println("取余数:"
+ bigInstance.divideAndRemainder(new BigInteger("3"))[1]);
// 取该大数字的2次方
System.out.println("做2次方操作:" + bigInstance.pow(2));
// 取该大数字的相反数
System.out.println("取相反数操作:" + bigInstance.negate());
三、Math.random()方法
用于的产生随机数,产生的随机数0<Math.random()<1.0
public static int GetEvenNum(double num1, double num2) {
// 产生num1~num2之间的随机数
int s = (int) num1 + (int) (Math.random() * (num2 - num1));
if (s % 2 == 0) { // 判断随机数是否为偶数
return s; // 返回
} else
// 如果是奇数
return s + 1; // 将结果加1后返回
}
public static void main(String[] args) {
System.out.println("任意一个2~32之间的偶数:" + GetEvenNum(2, 11));
random类(Java.util.Random)
通过实例化一个Random对象创建一个随机数生成器
Random r = new Random(); // 实例化一个Random类
// 随机产生一个整数
System.out.println("随机产生一个整数:" + r.nextInt());
// 随机产生一个大于等于0小于10的整数
System.out.println("随机产生一个大于等于0小于10的整数:" + r.nextInt(10));
// 随机产生一个布尔型的值
System.out.println("随机产生一个布尔型的值:" + r.nextBoolean());
// 随机产生一个双精度型的值
System.out.println("随机产生一个双精度型的值:" + r.nextDouble());
// 随机产生一个浮点型的值
System.out.println("随机产生一个浮点型的值:" + r.nextFloat());
// 随机产生一个概率密度为高斯分布的双精度值
System.out.println("随机产生一个概率密度为高斯分布的双精度值:"
+ r.nextGaussian());
}
四、Math类(精度要求比较高的运算不适合)
math类中提供了众多函数方法
// 取90度的正弦
System.out.println("90度的正弦值:" + Math.sin(Math.PI / 2));
System.out.println("0度的余弦值:" + Math.cos(0)); // 取0度的余弦
// 取60度的正切
System.out.println("60度的正切值:" + Math.tan(Math.PI / 3));
// 取2的平方根与2商的反正弦
System.out.println("2的平方根与2商的反弦值:"
+ Math.asin(Math.sqrt(2) / 2));
// 取2的平方根与2商的反余弦
System.out.println("2的平方根与2商的反余弦值:"
+ Math.acos(Math.sqrt(2) / 2));
System.out.println("1的反正切值:" + Math.atan(1)); // 取1的反正切
System.out.println("e的平方值:" + Math.exp(2)); // 取e的2次方
// 取以e为底2的对数
System.out.println("以e为底2的对数值:" + Math.log(2));
// 取以10为底2的对数
System.out.println("以10为底2的对数值:" + Math.log10(2));
System.out.println("4的平方根值:" + Math.sqrt(4)); // 取4的平方根
System.out.println("8的立方根值:" + Math.cbrt(8)); // 取8的立方根
System.out.println("2的2次方值:" + Math.pow(2, 2)); // 取2的2次方
// 返回第一个大于等于参数的整数
System.out.println("使用ceil()方法取整:" + Math.ceil(5.2));
// 返回第一个小于等于参数的整数
System.out.println("使用floor()方法取整:" + Math.floor(2.5));
// 返回与参数最接近的整数
System.out.println("使用rint()方法取整:" + Math.rint(2.7));
// 返回与参数最接近的整数
System.out.println("使用rint()方法取整:" + Math.rint(2.5));
// 将参数加上0.5后返回最接近的整数
System.out.println("使用round()方法取整:" + Math.round(3.4f));
// 将参数加上0.5后返回最接近的整数,并将结果强制转换为长整型
System.out.println("使用round()方法取整:" + Math.round(2.5));
}
System.out.println("4和8较大者:" + Math.max(4, 8));
// 取两个参数的最小值
System.out.println("4.4和4较小者:" + Math.min(4.4, 4));
System.out.println("-7的绝对值:" + Math.abs(-7)); // 取参数的绝对值
五、数字格式化
- Java中使用Java.text.DecimalFormat,格式化数字
- DecimalFormat类是NumberFormat的子类,用于格式化十进制数字
- 可通过DecimalFormat对象传递数字格式,也可通过DecimalFormat类中的applyPattern();方法类实现数字格式化
//实例化对象时设置格式化模式(默认模式)
static public void SimgleFormat(String pattern,double value){
DecimalFormat MyFormat = new DecimaFormat(pattern);
String output = MyFormat.format(value); //将数字格式化
System.out.printIn(value +"" +pattern + "" +output);
}
//使用applyPattern()方法对数字进行格式化 指定模式
static public void UseApplyPattern(String pattern,double value){
DecimalFormat MyFormat = new DecimalFormat();//实例化DecimalFormat对象
MyFormat.applyPattern(pattern);
System.out.println(value + " " + pattern + " " + myFormat.format(value));
}
//在mian主函数中调用
public static void main(String[] args){
SimgleFormat("###.###",1243.2145);
SimgleFormat("00000000.###kg", 123456.789); // 在数字后加上单位
// 按照格式模板格式化数字,不存在的位以0显示
SimgleFormat("000000.000", 123.78);
UseApplyPattern("#.###%",0.789); //将数字转化为百分数
("###.##", 123456.789); // 将小数点后格式化为两位
("0.00\u2030", 0.789); // 将数字转化为千分数形式
}
- 字符 含义
- 0 代表阿拉伯数字, 0表示数字的以为阿拉伯数字如果改为不存在水数字则显 示0
- # 每一个#代表一个阿拉伯数字,如果改为存在数字则显示字符 如果该位不存在数字则不显示
- . 小数分隔符
- - 负号
- , 逗号分组分隔符
- E 分隔科学计数法中的尾数和指数
- % 本符号放在数字的前面或后面,数字以百分数形式显示
- u2030 本符号放在数字的前缀或后缀,数字以千分数的形式显示
- u00A4 本符号放在数字的前缀或后缀,作为货币记号
- ’ 单引号,让特殊字符出现在数字中,应为特殊符号添加单引号,系统会将此符号视为普通符号处理
DecimalFormat myFormat = new DecimalFormat();
myFormat.setGroupingSize(2); // 设置将数字分组为2
String output = myFormat.format(123456.789);
System.out.println("将数字以每两个数字分组 " + output);
myFormat.setGroupingUsed(false); // 设置不允许数字进行分组
String output2 = myFormat.format(123456.789);
System.out.println("不允许数字分组 " + output2);