如何声明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));
i
和j
将自动取消装箱为<=
和>=
整数,但不是!=
。 i
和j
是不同的实例,但具有相同的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。