为何short s1 = 1;是对的,而float f=3.4;是错的?
整数直接量,默认是int型。所以int a = 4L; 会报错,但是long l = 4; 这样不会,因为这样会形成一个自动类型的转换,int类型自动转换为long类型 小数直接量,默认是double类型。所以float f = 3.4; 会报错,由double类型转为float类型是大转小,需要强转。 记住小类型转大类型会自动转换,大类型到小类型需要强转,因为会丢失精度或者溢出。(布尔型不参与,char类型相当于int类型) 整数直接量可以直接赋值给byte,short,char,但是不能超出范围。 byte,short,char型数据参与运算时,先一律转换为int再运算。
short s = 5;
s = s + 10; // 这里会出现编译错误,因为s参与运算,这时会自动转换为int型,s + 10 的值为int型,int型不能直接赋值给short型,需要强转
s += 10; // 这里不会出现错误,因为扩展赋值运算符自带强转功能