强制类型转换

xiaoxiao2021-02-28  52

这是对于127+1强制类型转换的结果是-128的原因的描述byte b = 127 + 1;//这样写报错:Type mismatch: cannot convert from int to byte所以必须强制类型转换:byte b = (byte) (127 + 1);因此就能理解为什么是-128了:int型的127在计算机内的二进制是:0000 0000 0000 0000 0000 0000 0111 1111加1后变成:0000 0000 0000 0000 0000 0000 1000 0000即128强制转换后截取低8位变成1000 0000这是byte类型-128的补码。 这是对于-129强制类型转换为byte的结果 1. int类型一般是4个字节,一个字节有8位,这样int型数据二进制的完整形式有32位,而byte表示一个字节,于是byte类型数据二进制的完整形式有8位。2. 二进制数据在计算机内是以二进制存储的,要注意一点,计算机在存储某个数据时,是存储的数据的补码,说明一下补码与原码关系,正数补码与原码相同,负数补码是原码减1后取反。3. 根据上面阐述,129的原码是00000000 00000000 00000000 10000001 ,负数最高位取1,那么-129便是10000000 00000000 00000000 10000001 ,补码计算:减1为10000000 00000000 00000000 10000000 ,再取反为11111111 11111111 11111111 01111111(最高位是符号位,不参与取反),现在转换为byte,只有8位,于是只能保留低8位,前面24位丢去,得到01111111,这就对应着十进制的127. 反正我看着有点绕,一 是对计算结果(补码)求原码 得到结果-128 -129的补码其实就是11111111 11111111 11111111 01111111所以两者都是对于补码在进行操作,然后计算结果需要换算成原码这里第二点计算补码的步骤和先取反末位加1有一点不同 结果是一样的得出的心得是,数据储存在计算机中,或者说只要参与运算(byte)也是运算,都是补码形式,最终被类型转换是在补码的基础上,然后得出结果再反算出原码,才是输出的结果
转载请注明原文地址: https://www.6miu.com/read-73275.html

最新回复(0)