C++中的自增运算符和自增1运算符有什么区别?
首先,两个操作都是自增操作,都只能对变量进行该操作,但是两种自增有些许区别
++x 先将x的值自增1,然后再在当前表达式中使用x的值。
x++ 先在当前表达式中使用x的值,然后再将x的值自增1。
举例:
(1)int x=1;System.out.println(x++); //输出1, x++先在当前表达式中使用x的值,然后再将x的值自增1,System.out.println(x); //输出2,经过上一条指令x自增了1
(2)int x=1;System.out.println(++x); //输出2, ++x 先将x的值自增1,然后再在当前表达式中使用x的值,System.out.println(x); //输出2,经过上一条指令x自增了1。
x++实际上分为三个步骤 取值,计算,赋值 例如x=1,x++, 实际上JVM定义了一个缓存值y y=x;取值(只运算一次) y=y+1;
计算 x=y;赋值 而++x,步骤不一样, y=x;取值(只运算一次) x=y;赋值 y=y+1;计算 这就是书上说的x++是先计算后赋值 ++x是先赋值后计算。
扩展资料
C的运算符有以下几类:
1、算术运算符:* - + / %
2、关系运算符: > < == != >= <=
3、逻辑运算符:! && ||
4、位运算符:<< >> ~ | ^ &
5、赋值运算符:=及扩展赋值运算符
6、条件运算符:?:
7、逗号运算符:,
8、指针运算符:*和&
9、求字节数运算符:sizeof
10、强制类型转换运算符:(类型)
11、分量运算符:、 ->
12、下标运算符:[ ]
13、其他:如函数调用运算符:()