Java中i++与++i的区别,如何分清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;

发布了8 篇原创文章 · 获赞 3 · 访问量 270

猜你喜欢

转载自blog.csdn.net/MillionSong/article/details/104204481