因为byte b = 13 ;
是常量的赋值。它的值在编译时是已知的,因此,如果常量值的赋值会导致溢出,则编译器可以/应该/会抱怨(尝试byte b = 123456789 ;
看看会发生什么。)。
将其分配给变量后,便要分配一个 表达式 的值,尽管它很可能是不变的,但编译器并不知道这一点。该表达式 可能 导致溢出,因此编译器发牢骚。
缩小类型转换:为什么在声明中允许将int分配给字节?
因为byte b = 13 ;
是常量的赋值。它的值在编译时是已知的,因此,如果常量值的赋值会导致溢出,则编译器可以/应该/会抱怨(尝试byte b = 123456789 ;
看看会发生什么。)。
将其分配给变量后,便要分配一个 表达式 的值,尽管它很可能是不变的,但编译器并不知道这一点。该表达式 可能 导致溢出,因此编译器发牢骚。