当java程序在进行赋值或者运算时,精度小的类型自动转换为精度大的类型即自动类型转换。
char--->int--->long--->float--->double
byte--->short--->int--->long--->float-->double
使用注意:
1. 有多种类型的数据混合运算时,系统首先将所有数据转换成容量最大的那种数据类型, 然后再进行运算
2. 当我们把精度大的数据类型赋值给精度小的数据类型时可能会精度丢失造成错误
3. (byte、short)和char 之间不会相互自动转换
4. byte、short,char 三者之间可以计算,在计算时首先转换为int类型。
5. Boolean 不参与转换
6. 自动提升原则: 表达式结果的类型自动提升为 操作数中最大的类型
强制类型转换:
自动类型转换的逆过程中,将精度大的转换为精度小的数据类型,使用时要加上强制转换符号(),但是可能导致精度丢失。
注意:
1. 当进行数据的大小从 大--->小,就需要用到强制转换符
2. 强制符号只针对于最近的操作数有效,往往会使用小括号提升优先级
3. char类型可以保存int的常量值,但不能保存int的变量值,需要强制转换。
4. byte 和short 类型再进行运算时,当做int类型处理。