java中i+和i到底应该怎么理解

2023-07-07 14:45 综合百科 0阅读 投稿:小七

一、i=i+1和i+=1

一、i=i+1和i+=1

(1)概念
i=i+1使用简单赋值运算,i+=1使用复合赋值运算

简单赋值运算和复合赋值运算的最大差别就在于:
  复合赋值运算符会自动地将运算结果转型为其左操作数的类型(即将不管i是什么数据类型,都会将右边int的1转换为i的类型)。
(2)实例

//方式一:byte i=7;i+=1;//方式二:byte i=7;i=i+1;

第一种写法编译没问题,而第二种写法却编译通不过。原因就在于,当使用复合赋值运算符进行操作时,即使右边算出的结果是int类型,系统也会将其值转化为左边的byte类型,而使用简单赋值运算时没有这样的优待,系统会认为将i+1的值赋给i是将int类型赋给byte,所以要求强制转换。

byte b=120b+=20;System.out.println("b="+b);//-116

上例中输出b的值不是140,而是-116。因为120+20的值已经超出了一个byte表示的范围,而当我们使用复合赋值运算时系统会自动作类型的转化,将140强转成byte,所以得到是-116。由此可见,在使用复合赋值运算符时还得小心,因为这种类型转换是在不知不觉中进行的,所以得到的结果就有可能和你的预想不一样。

二、i++和++i

i++是先传递结果后加,而++i刚好相反,是先加后传递结果。

(1)区别对比

1、赋值顺序不同

  ++ i 是先加后赋值;i ++ 是先赋值后加;++i和i++都是分两步完成的。

  因为++i 是后面一步才赋值的,所以它能够当作一个变量进行级联赋值,++i = a =b,即 ++i 是一个左值;i++ 的后面一步是自增,不是左值。

  形象的理解可以是i++先做别的事,再自己加1,++i先自己加1,再做别的事情。

2、效率不同

  比如i=3,b=i++就是说b=3,完成之后让i变成4,b=++i就是先让i++变成4,然后b=4,其中**++i比i++效率要高些**。一般来说在循环域里面,这两者并没有什么很大的区别,但是要注意其生存周期,以及i值在程序流中的变化。

3、 i++不能作为左值,而++i可以

  左值是对应内存中有确定存储地址的对象的表达式的值,而右值是所有不是左值的表达式的值。一般来说,左值是可以放到赋值符号左边的变量。

  但能否被赋值不是区分左值与右值的依据。比如,C++的const左值是不可赋值的;而作为临时对象的右值可能允许被赋值。左值与右值的根本区别在于是否允许取地址&运算符获得对应的内存地址。

(2)实例

for(int i=0; i<5; i++){ System.out.println(i+1);}//1 2 3 4 5for(int i=0; i<5; i++){ System.out.println(i++);}//0 2 4for(int i=0; i<5; i++){ System.out.println(++i);}//1 3 5
声明:若水百科所有作品(图文、音视频)均由用户自行上传分享,仅供网友学习交流。若您的权利被侵害,请联系youzivr@vip.qq.com