zoukankan      html  css  js  c++  java
  • 复合赋值操作符

    [java] view plain copy
     
    1. package common;  
    2.   
    3. public class ShortTypeTest {  
    4.   
    5.     /*    
    6.      * @param args 
    7.      */  
    8.     public static void main(String[] args) {  
    9.         // TODO Auto-generated method stub  
    10.         short s1 = 1; s1 = (short) (s1 + 1);//简单类型  
    11.         short s2=1; s2 +=1;//复合类型,复合赋值操作符+=,  
    12.         System.out.println(s1+";"+s2);  
    13.         //运行时Console输出什么,你知道吗?  
    14.     }  
    15.   
    16. }  

    关于一道Java面试题,今天没事就剖析了一下,供初学Java和不清楚的朋友参考学习。

    题目:

    short s1 = 1; s1 = s1 + 1;有什么错? short s1 = 1; s1 += 1;有什么错?

    解答:
    Java规范有这样的规则

    [

    1.高位转低位需要强制转换            

    2.低位转高位自动转.

    ]

    short s1 = 1; s1 = s1 + 1;有什么错? 

    答: i 是int 型   s1 short型 通过 + 运算后s1 自动转为int 型   所以错!

    short s1 = 1; s1 += 1;有什么错?

    答: 如果你认为表达式(x += i)只是表达式(x = x + i)的简写方式,这并不准确。

    这两个表达式都被称为赋值表达式。(x = x + i)表达式使用的是简单赋值操作符(=),而(x += i)表达式使用的是复合赋值操作符。Java语言规范中讲到,复合赋值(E1 op=E2)等价于简单赋值(E1=(T)((E1) op (E2))),其中T是E1的类型,除非E1只被计算一次。   换句话说,复合赋值表达式自动地将所执行计算的结果转型为其左侧变量的类型。如果结果的类型与该变量的类型相同,那么这个转型不会造成任何影响。然而,如果结果的类型比该变量的类型要宽,那么复合赋值操作符将悄悄地执行一个窄化原生类型转换。  

    因此,复合赋值表达式可能是危险的。为了避免这种令人不快的突袭,请不要将复合赋值操作符作用于byte、short或char类型的变量。 因为S1是short型的,占2个字节,而1是int型的,占4个字节。在两个类型的值相加的时候,会发生自动类型的提升,要不然数据也装不下呀,是这个道理吧*_*。也就是说s1+1后,其结果是int型的,而不是short型的,所以可以想想看,把4个字节的东西放在两个字节的空间里,肯定编译不通过。       

    后面的那个不会发生类型的提升,JAVA规范上说 【e1+=e2    实际上是    e1=(T1)(e1+e2) 】,其中T1是e1的数据类型。   s1+=1等效于   s1=(short)(s1+1),所以是正确的。     

  • 相关阅读:
    【Codeforces 1172F】—Nauuo and Bug(线段树+双指针)
    【Codeforces 1172F】—Nauuo and Bug(线段树+双指针)
    【BZOJ4671】—异或图(斯特林反演+线性基)
    【BZOJ4671】—异或图(斯特林反演+线性基)
    【Codeforces #453 E】—Little Pony and Lord Tirek(线段树/均摊分析)
    【Codeforces #453 E】—Little Pony and Lord Tirek(线段树/均摊分析)
    【Codeforces 480E】—Parking Lot(线段树+单调队列)
    【Codeforces 480E】—Parking Lot(线段树+单调队列)
    web安全
    Jodd——java瑞士军刀
  • 原文地址:https://www.cnblogs.com/pbq-dream/p/5294979.html
Copyright © 2011-2022 走看看