while( i <= j && i >= j && i != j) {}
如何声明i和j使其成为无限循环?
//这是我遇到的面试问题。
它询问i和j的声明是什么,让它永远是真的。
我无法通过将i和j声明为数字类型来实现。还有哪些类型可以满足它?
答案 0 :(得分:38)
Integer i=new Integer(1000);
Integer j=new Integer(1000);
System.out.println((i<=j)+" "+(i>=j)+" "+(i!=j));
i
和j
将自动取消装箱为<=
和>=
的整数,但不会!=
。 i
和j
是不同的实例,但具有相同的int值。这就是为什么所有三个比较都将返回真实的原因。
答案 1 :(得分:3)
这也有效(“在我的机器上”):
Integer a = 128, b = 128;
虽然这不起作用:
Integer a = 127, b = 127;
自动装箱int
是致Integer.valueOf(int)
的语法糖。此函数使用缓存来处理-128到127(包括端点)的值。 可以缓存其他值,但在我的情况下,它不会。
因此,128的赋值没有缓存命中;它为每个自动装箱操作创建一个新的Integer
实例,参考比较a != b
为真。 127的赋值具有缓存命中,并且生成的Integer
对象实际上是来自缓存的相同实例。因此,参考比较a != b
为假。
我真正想要指出的是提防与自动装箱的参考比较。更可能的现实问题是,您希望a == b
为真,因为它们被分配了相同的(自动装箱的)值,您运行了一些确认您的期望的单元测试,然后您的代码在野外“失败” “当某个计数器超过缓存的上限时。有趣的时光!
答案 2 :(得分:-2)
任何相等的'i'和'j'值都会在给定的陈述中显示为true,比如说:
Integer i = new Integer(1);
Integer j = new Integer(1);
while( i <= j && i >= j && i != j) {}
神奇的是用过的操作员!在!=运算符的情况下,编译器将操作数作为对象(包括它们的值),而在> gt或=&lt; =的情况下,编译器仅获取操作数值。因此,上面的语句返回true。