1、浮点类型的数据19.895989赋值给int类型,得到的结果为?描述为什么会得到该结果
int item = 19.895989;
//1、出现编译错误,double不能直接赋值给int
//可以通过强制类型转换实现赋值,但是有可能造成数据亏损
//2、转换--》int item = (int)19.895989;-->得到19【因为截取小数部分】
2、表达式中的自动类型提升顺序;强制类型转换要注意的地方
当表达式中有不同的数据类型进行运算时,会对小的数据类型进行类型提升,然后再进运算: 提升的顺序为
btye-->short-->int -->long-->float-->double
char-->int -->long-->float-->double
注意语法格式: 变量 a = (a变量的类型)变量 b;
注意对单个值还是整个表达式的结果进行转换;
举例: int result = (int)1.6+5.2;
// 错误: 不兼容的类型: 从double转换到int可能会有损失
3、分析操作一和操作二的结果,以及原因
short i = 3;
//操作一 i+=5;
//操作二 i=i+5;
System.out.println(i);
short i = 3;
//操作一 i+=5; ==》i=(i的数据类型)(i+5);
//操作二 i=i+5;
// 错误: 不兼容的类型: 从int转换到short可能会有损失
//1、i提升为int
//2、i+5==7{int}
//3、int{7}==》short?不能
System.out.println(i);
4、(1)计算6.5+6/5+8.1%3,描述计算过程【运算、类型提升、优先级、结合性】
1、(优先级)6/5==1 由于6和5都是int类型,所以结果也是为int
8.1%3==2.1--3要提升为double3.0 --再求余得到结果2.1
2、6.5+1;--1要提升为double --再相加得到结果7.5
3、7.5+2.1=9.6
(2)0xe4d2转换为2进制,再转换为10进制
0x e 4 d 2
二进制:1110 0100 1101 0010
m*16^(n-1)
十进制:14*16^3+4*16^2+13*16^1+2=58,578