执行时(幕后)会发生什么?
int x = 7;
x = x++;
也就是说,当一个变量在一条语句中被递增并分配给自己时?我编译并执行了这个。即使在整个表述之后X仍然是7。在我的书里,它说x是递增的!
执行时(幕后)会发生什么?
int x = 7;
x = x++;
也就是说,当一个变量在一条语句中被递增并分配给自己时?我编译并执行了这个。即使在整个表述之后X仍然是7。在我的书里,它说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++)修改原始变量时的微妙之处,因此很容易引入难以追踪的微妙错误。
其他回答
++x为增量前-> x在使用前为增量 x++是后增量-> X在使用后递增
int x = 7; -> x get 7 value <br>
x = x++; -> x get x value AND only then x is incremented
int x = 7;
x = x++;
它在C和Java中有未定义的行为,请参阅这个答案。这取决于编译器发生了什么。
这是因为您使用了后增量操作符。 在下面的代码行中
x = x++;
实际发生的情况是,你将x的值赋给x, x++在x赋给x后对x加1,这就是后加操作符的工作方式。它们在语句执行之后工作。所以在你的代码中,x先被返回然后再被递增。
如果你有
x = ++x;
答案是8,因为你使用了前增量操作符。这将在返回x值之前先对值进行递增。
增量发生在x被调用之后,所以x仍然等于7。当调用x时,++x将等于8
根据从类文件中获得的Byte码,
这两种赋值都增加x,但不同之处在于将值压入堆栈的时间
在Case1中,Push发生在增量之前(然后稍后分配)(本质上意味着您的增量不做任何事情)
在Case2中,Increment首先发生(使其为8),然后压入堆栈(然后分配给x)
案例1:
int x=7;
x=x++;
字节代码:
0 bipush 7 //Push 7 onto stack
2 istore_1 [x] //Pop 7 and store in x
3 iload_1 [x] //Push 7 onto stack
4 iinc 1 1 [x] //Increment x by 1 (x=8)
7 istore_1 [x] //Pop 7 and store in x
8 return //x now has 7
案例2:
int x=7;
x=++x;
字节码
0 bipush 7 //Push 7 onto stack
2 istore_1 [x] //Pop 7 and store in x
3 iinc 1 1 [x] //Increment x by 1 (x=8)
6 iload_1 [x] //Push x onto stack
7 istore_1 [x] //Pop 8 and store in x
8 return //x now has 8
Stack在这里指的是操作数Stack, local: x index: 1 type: int