数据类型的转化我个人认为就是存储之间的物质转移,请看下图:
整型类型的大小排行为:byte<short<int<long
浮点型的大小排行为:float<double
整型类型<浮点类型
注意:转大是可以自动转化的,但是大转小是要强制转换的。
自动转化:
一个int类型变量和一个byte类型变量进行加法运算,结果会是什么数据类型?
inti i=1;
byte b=2;
运算结果,变量的类型将是int类型,这就是出现了数据类型的自动类型转化现象。
自动转化:将取值最小范围小的类型自动提升为取值范围大的类型。
public static viod main(String[] args){
int i=1;
byte b=2;
/byte x=i+b;//报错
//int类型和byte类型运算,结果是int类型
int j=b+i;
System.out.print(j);}
转化就是把内存小的在转换过程中自动补充空间。
一个int类型变量和一个double类型变量进行加法运算,结果如何呢?
public static viod main(String[] args){
int i=1;
double b=2;
/int x=i+b;//报错
//int类型和double类型运算,结果是double类型
double j=b+i;
System.out.print(j);}
同样道理,当一个int类型变量和1个double变量运算时,int类型将自动提升为double类型进行计算
强制转会发生化:
将3.6赋值到int类型变量会发生什么?
int i=3.6//编译错误
double类型内存8个字节,int类型内存4个字节,3.6是属于double类型的,取值大于int类型。我们可以通俗的理解为double是8L的水壶。int是4L的水壶。不能把大水壶中的水全部装到小水壶里,会产生溢出现象。
转化格式
数据类型 变量名=(数据类型)被转化的数据;
将3.6赋值到int类型,代码修改为:
int i=(int)3.6;
注意:
- 浮点转化为整数,可能会造成数据丢失。
- int强制转换成short砍掉2个字节,可能造成数据丢失。