首先来看这段代码,这段代码在别的语言中可能是合法的,但在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
类型与其他类型运算时,也会进行相应的自动
类型提升。