如何声明i和j使其成为无限循环?

while( i = j && i != j) {} 

如何声明i和j使其成为无限循环?

//这是我遇到的面试问题。

它问的是i和j的声明是什么,让它永远是真的。

我不能通过将i和j声明为数字类型来实现。 还有哪些类型可以满足它?

 Integer i=new Integer(1000); Integer j=new Integer(1000); System.out.println((i<=j)+" "+(i>=j)+" "+(i!=j)); 

ij将自动取消装箱为<=>=整数,但不是!=ij是不同的实例,但具有相同的int值。 这就是为什么所有三个比较都将返回真实的原因。

这也有效(“在我的机器上”):

 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是真的,因为它们被分配了相同的(自动装箱的)值,你运行一些unit testing来确认你的期望,然后你的代码“在野外”失败当某个计数器超过缓存的上限时。 娱乐时间!

任何相等的’i’和’j’值都会在给定的陈述中显示出来,说:

 Integer i = new Integer(1); Integer j = new Integer(1); while( i <= j && i >= j && i != j) {} 

神奇的是使用过的操作员! 在!=运算符的情况下,编译器将操作数作为对象(包括它们的值),而在> =或<=的情况下,编译器仅获取操作数值。 因此,上面的语句返回true。