package com.wlh.test;
import java.math.BigDecimal;
import java.text.DecimalFormat;
public class Test {
/**
* @param args
*/
public static void main(String[] args) {
test5();
}
public static void test5() {
//====两个浮点数类型的字符串,如何转换为浮点相加,然后保持精度到小数点后2位呢?//
//转为float,精度丢失
float f = (float) (851570.78) + (float) (-23825.13);
//转为double,精度保持
double d = (double) (851570.78) + (double) (-23825.13);
double d2 = Double.parseDouble("851570.78")+ Double.parseDouble("-23825.13");
System.out.println(f);
System.out.println(d);
System.out.println(d2);
System.out.println("---------------------------------------------------------");
//转为float,精度保持
BigDecimal bigDecimal0 = new BigDecimal("851570.78");
BigDecimal bigDecimal1 = new BigDecimal("-23825.13");
//保持小数点后2位
BigDecimal bigDecima2 = new BigDecimal(bigDecimal0.floatValue()+ bigDecimal1.floatValue()).setScale(2,BigDecimal.ROUND_HALF_UP);
System.out.println(bigDecima2);
System.out.println("---------------------------------------------------------");
//转为double,精度保持
BigDecimal bigDecimal3 = new BigDecimal("851570.78");
BigDecimal bigDecimal4 = new BigDecimal("-23825.13");
//保持小数点后2位
BigDecimal bigDecimal5 = new BigDecimal(bigDecimal3.doubleValue()+ bigDecimal4.doubleValue()).setScale(2,BigDecimal.ROUND_HALF_UP);
System.out.println(bigDecimal5);
//====单个浮点数,如何保持精度到小数点后两位呢?=======================//
System.out.println("---------------------------------------------------------");
float a=134.567f;
//这种方法方便
float b1 = (float)(Math.round(a*100))/100;
System.out.println(b1);
//这个方法也简单,不过还要再转成float型:
String b2 = new DecimalFormat("###,###,###.##").format(a);
float b3=new Float(b2);;
System.out.println(b3);
//这个也可以用
BigDecimal bd = new BigDecimal((double)a); //转为double不会丢失精度
bd = bd.setScale(2,BigDecimal.ROUND_HALF_UP);
float b4 = bd.floatValue();
System.out.println(b4);
}
}
分享到:
相关推荐
经常为四舍五入的方法烦恼,新的思路重写四舍五入,并可以根据小数位数自动格式化,适合于数值型表格显示,该思路可适用于任何系统或数据库,代码比较乱,欢迎指正。
一个用 Oracle 编写货币大写转换(用过程编写支持转换小数点并且有四舍五入)
oracle 数字的四舍五入、去尾、收尾法
Oracle数据类型之Number, 全方位介绍Number数据类型。
自己写的Oracle四舍六入奇进偶不进的函数,实现了四舍六入五单进的修约规则,已经测试通过,并应用到项目中了!
四舍六入五成双:四舍六入五考虑,五后非零就进一,五后皆零看奇偶,五前为偶应舍去,五前为奇要进一。 注:修约时看保留小数的后一位为5时进行修约,其他按四舍五入情况。 修约:五后皆零看奇偶,修约看5前面那一...
一个用 Oracle 编写货币大写转换(函数可转换小数点并支持四舍五入)
oracle关于处理小数点位数的几个oracle函数(),小数点的处理以及实例
6、TIMESTAMP数据类型,和DATE相似,但是这个类型的秒精确到小数点后6位,而DATE没有秒的小数部分 7、LOB数据类型用于存储大型的,没有被结构化的数据,例如二进制文件,图片文件,LOB主要分为BLOB和CLOB,BLOB...
oracle常用函数介绍及其使用,初学者可以借鉴,只是一些简单的函数,如:1. ROUND(X[,...y是正整数,就是四舍五入到小数点后y位。ROUND(5.654,2)=5.65。 y是负整数,四舍五入到小数点左边|y|位。ROUND(351.654,-2)=400。
select round(1.66,1) from dual;-- 四舍五入,精确到1位小数 select round(1.56) from dual;-- 四舍五入,无小数 select trunc(89.115,2) from dual;-- 保留到小数位数
Oracle与.Net 数据类型映射,适用于.Net开发Oracle数据库。
oracle基本数据类型
oracle和sql数据类型
ORACLE 10g 数据类型 PPT ORACLE 10g 数据类型 PPT
Oracle与DB2数据类型的分类对应说明Oracle与DB2数据类型的分类对应说明
Oracle基本数据类型存储格式浅析(二)——数字类型 Oracle基本数据类型存储格式浅析(三)——日期类型 Oracle基本数据类型存储格式浅析(四)——ROWID类型 Oracle基本数据类型存储格式浅析(五)——RAW类型
oracle数据库中各种数据类型的详细说明
oracle新手入门指导之四——ORACLE数据类型 .txtoracle新手入门指导之四——ORACLE数据类型 .txt
oracle数据类型总结PPT,类型之间的区别