Java中i++与++i的区别和使用
书上对 i ++ 和 ++ i 的解释如下:
int i = 3,a = 0 ;
i ++ : 先赋值再运算;例如:a = i ++; 先赋值 a = i ,再运算 i = i + 1 ;所以输出结果为 a ==3;
++ i : 先运算再赋值;例如:a = i ++; 先运算 i = i + 1 ,再 赋值 a = i ;所以输出结果为 a ==4;
懂了吗?我想大部分人会跟我一样 一脸懵逼,明明都 + 1 了,咋上面输出结果是 3 下面就是 4 呢?哈哈~不要着急,接下来我将分享一下我对它们的理解,希望对你们有帮助。
认识“++”与“--”
“++”与“--”分别称作自增操作符和自减操作符,是对变量进行加 1 和减 1 的操作符。
认识 i + + 与 i - -
i++读为 i 加 加,i--读为 i 减减,这些操作符分别称为后置自增操作符和后置自减操作符。
以 i++为例,先来介绍一下i++, i++ 的计算方法分为以下5个步骤
- 先开批一个临时存储区
- 将 i 的值复制到存储区
- i 自身+1
- 临时存储区的值等待被调用(参与运算、输出、赋值)
- 若 i 被调用则输出值为 i ,否则输出 i++
图解如下:
接下来我会举例说明
public class test{
public static void main(String[] args){
int i = 3;
/*
创建一个变量i,里面放i的初始值3,先开辟一个临时存储区,
将i的值复制到存储区,此时存储区里面i的值为3
*/
i ++;//i自身加1,此时i的值为4
System.out.print(i);//打印输出i,因为i没有被调用,故输出i自身的值4
System.out.print(i++);
/*
上一行代码中i的值已经变成了4,再开辟一个临时存储区,
将i的值复制到存储区,此时存储区里面i的值为4,i自身的值+1变为5;
i++被输出调用,故输出存储区的值4
*/
int j = i++;
System.out.print(j);
/*
上一行代码中i的值已经变成了5,再开辟一个临时存储区,
将i的值复制到存储区,此时存储区里面i的值为5,i自身的值+1变为6;
i++被赋值调用,故输出存储区的值5
*/
System.out.print(i);//没被调用,故打印值为i自身的值6
i = i++;
System.out.print(i);
/*
上一行代码中i的值已经变成了6,再开辟一个临时存储区,
将i的值复制到存储区,此时存储区里面i的值为6,i自身的值+1变为7;
i++被赋值调用,故输出存储区的值6
*/
i = i++;
System.out.print(i);
/*
上一行代码中i的值为6,再开辟一个临时存储区,
将i的值复制到存储区,此时存储区里面i的值为6,i自身的值+1变为7;
i++被赋值调用,故输出存储区的值6
*/
}
}
同理可得 i - - 的计算方法如下,
- 先开批一个临时存储区
- 将 i 的值复制到存储区
- i 自身 -1
- 临时存储区的值等待被调用(参与运算、输出、赋值)
- 若 i 被调用则输出值为 i ,否则输出 i - -
举例说明
public class test01{
public static void main(String[] args){
int i = 5;
/*
创建一个变量i,里面放i的初始值5,先开辟一个临时存储区,
将i的值复制到存储区,此时存储区里面i的值为5 */
i--;//i自身减1,此时i的值为4
System.out.println(i);//打印输出i,因为i没有被调用,故输出i自身的值4
System.out.print(i--);
/*
上一行代码中i的值已经变成了4,再开辟一个临时存储区,
将i的值复制到存储区,此时存储区里面i的值为4,i自身的值-1变为3;
i--被输出调用,故输出存储区的值4
*/
int j = i--;
System.out.print(j);//3
/*
上一行代码中i的值已经变成了4,再开辟一个临时存储区,
将i的值复制到存储区,此时存储区里面i的值为4,i自身的值-1变为3;
i--被赋值调用,故输出存储区的值3
*/
System.out.print(i);//没被调用,故打印值为i自身的值3
i = i--;
System.out.print(i);//2
/*
上一行代码中i的值已经变成了3,再开辟一个临时存储区,
将i的值复制到存储区,此时存储区里面i的值为3,i自身的值-1变为2;
i--被赋值调用,故输出存储区的值2
*/
}
}
认识+ + i 与 - - i
++i 读作加加i,--i读作减减i,分别称作前置自增操作符和前置自减操作符。
相对于i++来说,++i 的运算思路比较简单,只进行简单的+1操作即可。
举例说明:
public class test{
public static void main(String[] args){
i = 1;
j = i++ + ++i + ++i + i++;
// 1 3 4 4
/*
i++: 赋值调用,故打印值为1,临时存储区放的值为2
++i:i的值+1,故值为3
++i:i的值+1,故值为4
i++:赋值调用,故输出临时存储区的值4,i自身值+1为5
*/
System.out.print(j);//故输出结果为12
System.out.print(i);//没有参与调用,故输出i自身的值5
System.out.print(++i);//输出值为6
同理,--i ,也只是在自身基础上- 1即可。
举例说明:
public class test01{
public static void main(String[] args){
int i = 5;
--i;
System.out.println(i);//i自身减1,值为4
System.out.print(--i);//i自身减1,值为3
}
}
使用自增操作符和自减操作符可以使表达式更加简短,但也会使它们比较复杂且难以读懂。比如上述代码中出现的 j = i++ + ++i + ++i + i++; 只是为了测试大家是否更好的掌握了i ++与 ++ i,但在实际编程过程中应该避免。
我的总结如下:
- i++、i-- :若参与调用,输出值不 +1,否则 +1
- ++i、--i :无论是否参与调用,输出值均 +1
- 希望大家在读懂我上述描述的基础上,再合理运用这两句话 ~
附:文章开头那道题,现在用我的方法来做,是不是易如反掌啦~
int i = 3,a = 0 ;
i ++ : 例如:a = i ++;因为赋值调用了,所以输出值为临时存储区先复制的i的值,即 a ==3;
++ i : 例如:a = i ++; 输出结果直接 +1 即结果为 a ==4;
以上是 Java中i++与++i的区别和使用 的全部内容, 来源链接: utcz.com/z/323381.html