偶尔碰到一些感觉很常见但是碰到了却又有些模糊的问题,然后花了点时间一下性解决下,写下来以后回来再看。

  直接看代码分析吧

1 package myInterviewProgram;
 2 public class TestByte {
 3     /*
 4      * 首先表达式转型注意以下规则:
 5         ①所有的byte,short,char型的值将被提升为int型;
 6         ②如果有一个操作数是long型,计算结果是long型;
 7         ③如果有一个操作数是float型,计算结果是float型;
 8         ④如果有一个操作数是double型,计算结果是double型;
 9             首先2个byte类型相加,会自动提升为int,计算的结果也是int因此需要强制转化会byte,
10         而被fianl修饰的变量不会改变,会被JVM优化,当2个final修饰相加时候会根据左边变量的类型而转化,
11         作为这2个final变量的最终类型。
12      */
13     /*
14      * 基本数据类型转换:
15     各数据类型按容量大小(表数范围大小)由小到大排列为:
16      Byte, short, char  ——int ——long——float——double
17       1.转换时遵循的原则:
18      1)容量小的类型自动转换为容量的类型;
19      2)容量大的类型转换为容量小的类型时,要加强制转换符;
20     3)byte,short,char之间不会互相转换,并且三者在计算时首先转换为int类型;
21     4)实数常量默认为double类型, 整数常量默认为int类型;
22      */
23     public static void main(String[] args){
24         
25         byte a =1,b=2,l=127;
26         final byte e=3,f=4,t=127;
27         int k = 3;
28         //先来最基本的:
29 //        a = k;//编译错误,int型赋值给byte需要强制类型转换
30         k = a;//编译通过,byte可以直接转换成为int型及以上基本数据类型
31         System.out.println(k);
32         
33         int x = a+b;//编译通过,两个byte型数据相加自动转换为int型
34 //        byte x1 = a+b;//这句报错,因为byte类型数据在计算时会自动转换成为int型参与计算,所以a+b得到的结果是int型的
35         byte x1 = (byte) (a+b);//int型强转byte,精度会丢失
36         
37         byte x2 = a++;//编译通过
38         int x3 = a++;//编译也通过
39         byte x4_ = ++l;//编译居然通过了,结果为-128,其实是先转换成了int型结果自增为128,但是byte型范围最大为127,底层自动发生了向下转换,丢失了精度。
40 //        byte x4 = 1++;//编译不通过,说明++操作底层也是自动转换了int型
41 //        byte x4 = e++;//编译不通过
42 //        byte x4 = ++t;//编译不通过,通过与上一条语句对比说明,经过final修饰的byte基本数据类型变量,经过++、--操作都不能赋值给非final。
43         
44 //        byte x5 = a+1;//编译不通过,原因:1为int型,与byte型数据相加结果自动转int
45         byte x5 = 1+2;//编译通过了,首先要注意1、2这是两个常量,编译器会直接将这两个常量相加后赋值,
46         //相当于直接赋值操作,所以正确。
47         System.out.println(x4_);
48         
49         int y = e+f;//编译通过
50         byte y1 = e+f;//编译也通过,说明当两个byte型都被final修饰时,相加byte,int都是正确的。我们可以这样理解,经过final修饰
51         //的变量是不可改变的,所以可以当常量处理,相当于先计算了两个byte常量值,再将结果赋值给左边的变量,也就是初始化操作。
52         //必须要说明的,当e+f的结果超过byte范围-128-127时,此时赋值就会报错。
53         
54         int z = a+e;//编译通过
55 //        byte z1 = a+e;//报错,通过对比说明只要有byte型数据相加,都会发生向上转型为int,不管其中是否一个是final
56         byte z1 = (byte) (a+e);//可以通过强转型
57 //        System.out.println(x2);
58         
59     }
60 }
总结下:
1、对于数据类型的相加,当操作数是byte,short,char时,会自动转化为int类型;返回结果为int。当操作数是int,long时,不转化,原来是啥类型,还是啥类型。
2、对于有final修饰的基本数据类型,当两个操作数都被final修饰,可以直接当常量处理,例如相加操作,会直接相加取结果再如初始化方式赋值,所以左边变量数据类型只要是在结果范围类都是正确的;当两个操作数有一个不是final,最后会将结果转换为int型,如果左边不是int型变量,需要转换数据类型。
3、对于++、--操作,经过final修饰的变量不能直接赋值给非final型,否则直接报错。。但是允许其中一个是final型,只不过最后结果是int型,需要强转。