执行时(幕后)会发生什么?
int x = 7;
x = x++;
也就是说,当一个变量在一条语句中被递增并分配给自己时?我编译并执行了这个。即使在整个表述之后X仍然是7。在我的书里,它说x是递增的!
执行时(幕后)会发生什么?
int x = 7;
x = x++;
也就是说,当一个变量在一条语句中被递增并分配给自己时?我编译并执行了这个。即使在整个表述之后X仍然是7。在我的书里,它说x是递增的!
当前回答
当你为x重新赋值时,它仍然是7。尝试x = ++x,你会得到8个其他的
x++; // don't re-assign, just increment
System.out.println(x); // prints 8
其他回答
X确实增加了。但是你把原来的x值赋回了自身。
x = x++;
x++增加X并返回其旧值。 X =将旧值赋回给自身。
最后,x被赋回了它的初始值。
我认为这个争议是可以解决的,不需要进入代码,只需要思考。
考虑i++ & ++i作为函数,比如Func1和Func2。
现在我= 7; Func1(i++)返回7,Func2(++i)返回8(大家都知道)。在内部,这两个函数都将i增加到8,但它们返回不同的值。
i = i++调用函数Func1。在函数内部,i增加到8,但完成后函数返回7。
所以最终7被分配给i(最后i = 7)
增量发生在x被调用之后,所以x仍然等于7。当调用x时,++x将等于8
x = x++;
这是后增量操作符。它应该理解为“使用操作数的值,然后增加操作数”。
如果你想要发生相反的情况,即“增加操作数,然后使用操作数的值”,你必须使用预增加操作符,如下所示。
X = ++ X;
这个运算符首先将x的值加1,然后将值赋回给x。
像x = x++;表明你可能误解了++操作符的作用:
// original code
int x = 7;
x = x++;
让我们重写它来做同样的事情,基于删除++操作符:
// behaves the same as the original code
int x = 7;
int tmp = x; // value of tmp here is 7
x = x + 1; // x temporarily equals 8 (this is the evaluation of ++)
x = tmp; // oops! we overwrote y with 7
现在,让我们重写它(我认为)你想要的:
// original code
int x = 7;
x++;
这里的微妙之处在于,++操作符修改变量x,这与x + x等表达式不同,后者将计算为int值,但变量x本身不变。考虑一个像值得尊敬的for循环这样的结构:
for(int i = 0; i < 10; i++)
{
System.out.println(i);
}
注意到里面的i++了吗?这是同一个算子。我们可以像这样重写这个for循环,它的行为是一样的:
for(int i = 0; i < 10; i = i + 1)
{
System.out.println(i);
}
我还建议在大多数情况下不要在较大的表达式中使用++运算符。由于它在增量前和增量后(分别是++x和x++)修改原始变量时的微妙之处,因此很容易引入难以追踪的微妙错误。