自动转换
这种转换发生在不同数据类型的量混合运算或赋值时,由编译系统自动完成。自动转换遵循以下规则: 1,若参与运算量的类型不同,则先转换成同一类型,然后进行运算。,2,转换时按数据长度增加的方向进行,以保证精度不降低。如int型和long型运算时,先把int量转成long型后再进行运算。 3,所有的浮点运算都是以双精度进行的,即使仅含float单精度量运算的表达式,也要先转换成double型,再作运算。
4,char型和short型参与运算时,必须先转换成int型。 5,在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边量的类型将转换为左边量的类型。如果右边量的数据类型长度左边长时,将丢失一部分数据,这样会降低精度,丢失的部分按四舍五入向前舍入。
强制类型转换
强制类型转换是通过类型转换运算来实现的,形式为在要转换的数值或者表达式前用小括号将要类型括起来。比如要将double类型的数据强制转换为int型:
double d = 1.234; float f = 5.678; int i = (int)d;
也可以是整个表达式的转换:
long l = (long)(d + f);
在使用强制转换时应注意以下问题:
1,类型说明符和表达式都必须加括号(单个变量可以不加括号),如把(int)(x+y)写成(int)x+y则成了把x转换成int型之后再与y相加了。
2,无论是强制转换或是自动转换,都只是为了本次运算的需要而对变量的数据长度进行的临时性转换,而不改变数据说明时对该变量定义的类型,也就是被强制转换的变量或表达式本身还是原来的类型。