Java中i++与++i的区别和使用
书上对 i ++ 和 ++ i 的解释如下:
10年积累的成都网站建设、网站设计经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站设计后付款的网站建设流程,更有陵川免费网站建设让你可以放心的选择与我们合作。
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的区别和使用
文章来源:http://pwwzsj.com/article/pjipip.html