Integer和int的区别
int是java提供的8种原始数据类型之一。默认值为0
Integer是java为int提供的封装类。默认值为null
Integer可以区分出未赋值和值为0的区别,int则无法表达出未赋值的情况
什么时候用Integer?什么时候用int?
要想表达出没有参加考试和考试成绩为0的区别
在JSP开发中,Integer的默认为null,所以用el表达式在文本框中显示时,值为空白字符串,而int默认的默认 值为0,所以用el表达式在文本框中显示时,结果为0,所以,int不适合作为web层的表单数据的类型。
在Hibernate中,如果将OID定义为Integer类型,那么Hibernate就可以根据其值是否为null而判断一个对象是否 是临时的,如果将OID定义为了int类型,还需要在hbm映射文件中设置其unsaved-value属性为0。
Integer提供了多个与整数相关的操作方法,例如,将一个字符串转换成整数,Integer中还定义了表示整数的最 大值和最小值的常量。
问题:
以下代码中的情况是怎么回事?
在此要了解Integer的自动拆箱和装箱 链接:Integer
浮点型精度丢失问题
解释:出现以上问题的原因是浮点数有精度丢失的问题。因为计算机只识别 0 和 1,所以数值都是以二进制的方式储存在内存中的。具体可参考 浮点数的 IEEE 745标准。int数值是连续且等分的,而float数值是跳跃的,并且间隔不一定相等。都是用32位表示,也就是说int和float可存储数值的最大数量是相等的,为2的32次方。用一幅图来表示:
说白了精度太高,你输入个浮点型的0.1,字面上是0.1,实际上可能是0.15843456145624....在负数值范围内,float可以表示更加精确的数(图中较为密集的部分),但是在正数范围中,float表示的就不如int精确了,并且float数值不是等分表示的,这就造成了float的精度丢失。最根本原因还是计算机只能采取二进制存储数据。
注意:float 有限 离散 舍入误差 大约 接近但不等于
最好完全避免使用浮点数进行比较
银行业务中,钱数用什么类型?你敢用浮点型?
银行存钱,用的是一个数学工具类——BigDecimal
BigDecimal构造方法
1.public BigDecimal(double value) 将double表示形式转换为BigDecimal *不建议使用
2.public BigDecimal(int value) 将int表示形式转换成BigDecimal
3.public BigDecimal(String value) 将String表示形式转换成BigDecimal
为什么不建议第一种?原因如下
JDK的描述:1、参数类型为double的构造方法的结果有一定的不可预知性。有人可能认为在Java中写入newBigDecimal(0.1)所创建的BigDecimal正好等于 0.1(非标度值 1,其标度为 1),但是它实际上等于0.1000000000000000055511151231257827021181583404541015625。这是因为0.1无法准确地表示为 double(或者说对于该情况,不能表示为任何有限长度的二进制小数)。这样,传入到构造方法的值不会正好等于 0.1(虽然表面上等于该值)。
2、另一方面,String 构造方法是完全可预知的:写入 newBigDecimal("0.1") 将创建一个 BigDecimal,它正好等于预期的 0.1。因此,比较而言,通常建议优先使用String构造方法。
网友评论