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


一、找奇数:

public static boolean isOdd(int i){java

return i % 2 == 1;编程

}编程语言

上面的方法真的能找到全部的奇数么?优化

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

2. 浮点数相减io

System.out.println(2.0-1.9);for循环

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是不可达语句,在编译阶段将优化去掉。

相关文章
相关标签/搜索