第二章:08运算符[赋值运算符]

①符号:=

☞当“=”两侧数据类型不一致时,可以使用自动类型转换或使用强制类型转换原则进行处理。

☞支持连续赋值。

②扩展赋值运算符
+=, -=, *=, /=, %= 隐含了一个强制类型转换

1+= 把左边和右边做加法,然后赋值给左边。

int y = 10;

y += 20;//等价于  y = ( y的数据类型)( y + 20);

System.out.println(y);//30

 

 

 

③实例

/*

运算符之二:赋值运算符

=  +=  -=  *=  /=  %=

*/

class SetValueTest {

   public static void main(String[] args) {

       //赋值符号:=

       int i1 = 10;

       int j1 = 10;

       int i2,j2;

       //连续赋值

       i2 = j2 = 10;

       int i3 = 10,j3 = 20;

       //*********************

       int num1 = 10;

       num1 += 2;//num1 = num1 + 2;

       System.out.println(num1);//12

       int num2 = 12;

       num2 %= 5;//num2 = num2 % 5;

       System.out.println(num2);

       short s1 = 10;

       //s1 = s1 + 2;//编译失败

       s1 += 2;//结论:不会改变变量本身的数据类型

       System.out.println(s1);

       //开发中,如果希望变量实现+2的操作,有几种方法?(前提:int num = 10;)

       //方式一:num = num + 2;

       //方式二:num += 2; (推荐)

       

       //开发中,如果希望变量实现+1的操作,有几种方法?(前提:int num = 10;)

       //方式一:num = num + 1;

       //方式二:num += 1;

       //方式三:num++; (推荐)

       

       //练习1

       int i = 1;

       i *= 0.1;//等价于  i = (int)( i* 0.1);

       System.out.println(i);//0

       i++;

       System.out.println(i);//1

       //练习2

       int m = 2;

       int n = 3;

       n *= m++; //n = n * m++;    

       System.out.println("m=" + m);//3

       System.out.println("n=" + n);//6

       

       //练习3

       int n1 = 10;

       n1 += (n1++) + (++n1);//n1 = n1 + (n1++) + (++n1);   10 +10 +12

       System.out.println(n1);//32

   }

}

 

④面试题

1、 short s=1;s = s+1;

    short s=1;s += 1;

    上面两个代码有没有问题,如果有,那里有问题。

    为什么第二个木有问题呢?

    扩展的赋值运算符其实隐含了一个强制类型转换。

    s += 1;

    不是等价于 s = s + 1;

    而是等价于 s = (s的数据类型)(s + 1);

    //short s = 1;

    //s = s + 1;

    //System.out.println(s);

    short s = 1;

    s += 1; //好像是 s = s + 1;

    System.out.println(s);

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 

 
 

 

 

 

 

 

 

 

 

 

 
 

 

转载于:https://www.cnblogs.com/Lucky-stars/p/11007645.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值