1.自动转换(隐式转换):
自动转换发生在不同数据类型的变量混合运算时,由编译系统自动完成
自动转换遵循以下规则:
1)若参与运算量的类型不同,则先转换成同一类型,然后进行运算
如输出2.3+1,会转换成浮点型进行计算
2)转换按数据长度增加的方向进行,以保证精度不降低。如int型和long型运算时,先把int型转换成long型,再做运算
3)所有的浮点运算都是以双精度进行的,即使两个float单精度量运算的表达式,也要先转换成double型,再做运算
4)char型和short型参与运算时,必须先转换成int型
如输出'a'+1
5)在赋值运算中,赋值号两边量的数据类型不同时,赋值号右边量的类型将转换成左边量的类型。如果右边量的数据类型长度比左边长时,将丢失一小部分数据,这样会降低精度。
如int a=2.3+1; int b=2.6+1;会直接省略小数点后面的数据。
2.强制类型转换(显式转换)
为什么要进行强制类型转换?
如在团队中对接口的时候这边要求是int型,但是那边给的是double型,这样类型不一致,团队协调代价大,可采用强制类型转过来,也是为了编译通过。
其一般形式为:
(类型说明符)(表达式)
其功能是把表达式的运算结果强制转换成类型说明符所表示的类型。
如(float)a:把a转换成浮点型
(int)(x+y):把x+y的结果转换成整型