网页制作基础教程直播/成都官网seo厂家
首先来看这段代码,这段代码在别的语言中可能是合法的,但在java中不行,则会在编译中出现错误;
byte a = 10, b = 20;byte c = a+b;
运行结果:
如上代码所示尽管 a 和 b 两个变量都是 byte 类型,但是 Java 为临时变量选择类型时,会将这个类型“自动的提升”为 int 类型(Java中变量类型一般默认为int型),大小为 4 个字节。于是,上述过程中,就 成了把一个 int 类型赋值给 byte 类型的操作,从而产生一个编译时错误。这就是 Java 语言中的自动类型提升特性。
要避免这个问题,只需要对其结果进行强制类型转换即可。即把原代码改为:
byte c = (byte)(a+b);
需要注意的是,由于是对 a+b 的结果进行强制转换的,因此需要对 a+b 这个表达式加上括号。
Java 自动类型提升的规则如下:
1. 如果运算数中存在 double,则自动类型提升为 double
2. 如果运算数中没有 double 但存在 float,则自动类型提升为 float
3. 如果运算数中没有浮点类型,但存在 long,则自动类型提升为 long
4. 其他所有情况,自动类型提升为 int。
换而言之,byte + byte,byte + short 之类的运算,都会被自动提升为 int 类型。需要说
明的是,char 类型也能进行运算,并且 char 类型与其他类型运算时,也会进行相应的自动
类型提升。