public class Test{
public static void main(String args[]){
System.out.println(0.05+0.01);
System.out.println(1.0-0.42);
System.out.println(4.015*100);
System.out.println(123.3/100);
}
};
你没有看错!结果确实是
0.060000000000000005
0.5800000000000001
401.49999999999994
1.2329999999999999
Java中的简单浮点数类型float和double不能够进行运算。不光是Java,在其它很多编程语言中也有这样的问题。在大多数情况下,计算的结果是准确的,但是多试几次(可以做一个循环)就可以试出类似上面的错误。
float和double只能用来做科学计算或者是工程计算,在商业计算中我们要用 java.math.BigDecimal,如果使用oracle数据库,数字字段通常使用number,不用限定小数位数,因为在某些商业计算中是无法确定小数位数的,java中一定要使用BigDecimal来进行计算,然后在转化成Double 存到数据库中。建表语句参考如下:
create tablePO.PO_LINES_ALL
(
PO_LINE_IDNUMBER not null,
LAST_UPDATE_DATE DATEnot null,
LAST_UPDATED_BYNUMBER not null,
PO_HEADER_IDNUMBER not null,
LINE_TYPE_IDNUMBER not null,
LINE_NUMNUMBER not null,
LAST_UPDATE_LOGINNUMBER,
CREATION_DATE DATE,
CREATED_BYNUMBER,
ITEM_IDNUMBER,
ITEM_REVISIONVARCHAR2(3),
CATEGORY_IDNUMBER,
ITEM_DESCRIPTIONVARCHAR2(240),
UNIT_MEAS_LOOKUP_CODEVARCHAR2(25),
QUANTITY_COMMITTEDNUMBER,
COMMITTED_AMOUNTNUMBER,
ALLOW_PRICE_OVERRIDE_FLAGVARCHAR2(1),
NOT_TO_EXCEED_PRICENUMBER,
LIST_PRICE_PER_UNITNUMBER,
UNIT_PRICENUMBER,
QUANTITYNUMBER,
AMOUNTNUMBER)
本文参考: