Java隐式转换发生在编译期,仅支持小容量→大容量的安全转换,如int→long、char→int,不兼容boolean及窄化转换,但常量赋值例外。
Java中的自动类型转换(也叫隐式转换)发生在编译期,由编译器根据类型兼容性和数据范围关系自动完成,不需要程序员写强制转换符号。它只允许“小容量→大容量”的安全转换,比如int转long、float转double,但反过来会报错。
隐式转换主要出现在赋值、方法调用、算术运算和返回语句中,前提是目标类型能无损容纳源类型的全部取值范围。
int i = 10; long l = i;,i被自动转为long
byte + short),先统一提升到int
再计算;int + long则提升为long
double参数的方法时传入int,编译器自动转成double
long,但实际返回int字面量或变量,也允许隐式转换Java按数据表示范围从小到大排列为:byte → short → int → long → float → double,char可隐式转为int及以上(因为其数值范围0~65535在int内),但char和byte/short之间不互相转换(无符号/有符号差异导致不安全)。
byte、short、char在参与运算时,一律先提升为int——这是Java的“小型类型提升规则”int可以隐式转long、float、double;long可转float、double(注意:long → float可能丢失精度,但编译器仍允许)boolean不参与任何隐式转换,和其它类型完全不兼容编译器拒绝一切可能丢失信息或语义模糊的转换,哪怕看起来“合理”。这类错误在编译阶段就被拦截,不等到运行时。
int不能隐式转short或byte(范围缩小,可能溢出)double不能隐式转float(精度损失过大,需显式强转)char不能隐式转byte或short(虽然数值上可能不越界,但Java明确禁止)当使用字面量或编译期可确定的常量表达式时,Java允许窄化转换,但仅限于赋值场景,且要求值在目标类型范围内。这是编译器做的额外优化,不是通用隐式转换规则。
byte b = 10; 合法——10是int字面量,但编译器确认它在byte范围内,允许隐式窄化final int x = 20; byte b = x; 合法——x是编译期常量int y = 30; byte b = y; 编译失败——y非常量,无法保证运行时不越界