首先我们来看自动类型转换。自动类型转换有两个条件: 1.转换前后的数据类型兼容;2.转换后的数据类型的范围大于转换前的数据类型。
抄的
话不多说 直接上代码
short sh = 16385;
int in = sh;
byte by = sh;// 这行编译会报错。
byte by = (byte) sh;// 要改成强制类型转换。
我们都知道,机器是只能识别二进制的代码,所以我们把sh
转成二进制。
sh = 16485 -> 0100 0000 0000 0001
这个时候可能有人会有疑问,为什么整了个0100
,1000
不香吗?
答案很简单,我不想
。
对不起对不起。
实际上是我大意了。没有闪
我在将1000 0000 0000 0001
转换为二进制的时候,得到的结果是32769
,你们可以试一下,不能存储为short类型。
有的人可能一开始心里就有答案,有的人可能还没想明白。
其实很简单,第一位是正负数的标记
。
我不知道怎么描述的更官方有点,有没有大佬能补充下…
好了,回到正题。
我们得到了一个二进制的16位的数,如果把它转为int类型, 也就是32位,学过计算机应该都知道,前面补0
就完事了,所以结果是:
int in = 16485 -> 0000 0000 0000 0000 0100 0000 0000 0001
最后的结果是不变的,16485,神奇不神奇。
但是,当我们把它强转为byte类型时,8位,怎么转?
接下来是猜测环节,因为我饿了,稍等去查验下正确的逻辑。
我猜测应该是去掉了红框中的8位字节码。
实际上,以这个数字来说,去掉前8位和去掉红框中的8位得到的结果都是1,但是,它肯定去掉了红框中的8位。
你要问为什么,因为当我用 -16385
去实验时,得到的结果是-1
,而且前面也说了,第一位是用来标记正负数的,所以应该也不会算在这个逻辑里面。