美文网首页
Java 中的陷阱题,你知道几个?

Java 中的陷阱题,你知道几个?

作者: java技术分享师 | 来源:发表于2019-01-29 19:11 被阅读0次

1、找奇数:

public static boolean isOdd(int i){

return i % 2 == 1;

}

上面的方法真的能找到所有的奇数么?

A:没有考虑到负数问题,如果i为负则不正确。应该return i%2 == 0

2. 浮点数相减

System.out.println(2.0-1.9);

A:Java中的简单浮点数类型float和double不能够进行运算。不光是Java,在其它很多编程语言中也有这样的问题。在大多数情况下,计算的结果是准确的,但是多试几次(可以做一个循环)就可以试出类似上面的错误。当然加减乘除都有可能有问题,比如:

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);

这是因为有些十进制有限位数的小数,到二进制里面可能会变成无限循环小数,在浮点数中不能表示而损伤精度。

解决方法:

2.1. 如果是判断a-b是否等于c,或者a+b是否等于c的,可以使用

if(0.05+0.01-0.06 < 0.0000001)

{

}

2.2. 在《Effective Java》这本书中提到一个原则,float和double只能用来做科学计算或者是工程计算,在商业计算中我们要用 java.math.BigDecimal来解决

System.out.println((new BigDecimal("2.0")).subtract(new BigDecimal("1.9")).doubleValue());

3. 无限循环

public static final int END = Integer.MAX_VALUE;

public static final int START = END - 2;

public static void main(String[] args) {

int count = 0;

for (int i = START; i <= END; i++)

count++;

System.out.println(count);

}

A:这里无限循环的原因就是当i为Integer.MAX_VALUE时,此时for循环是先++,然后判断i是否<=END,当i为Integer.MAX_VALUE再++时,i变成了负数。所以就一直循环下去。

变成负数的原因就是int溢出了。这里将<=END改成<END就可以解决问题。

4. 到底返回什么?

public static boolean decision() {

try {

return true;

} finally {

return false;

}

}

A:返回false。此时return true是不可达语句,在编译阶段将优化去掉。

相关文章

网友评论

      本文标题:Java 中的陷阱题,你知道几个?

      本文链接:https://www.haomeiwen.com/subject/vjqfsqtx.html