基本概念:在Java中
int的取值范围为(-2147483648~2147483647)占用4个字节;
byte的取值范围为(-128~127),占用1个字节;
short的取值范围为(-32768~32767),占用2个字节;
long的取值范围(-9223372036854774808~9223372036854774807),占用8个字节。
当int类型强制转换成为byte类型时,计算机会截取最末一个字节(后八位)
在计算机存储数据时,其在内存中都是以补码的形式进程存储
所以,我们看到的数字都是计算机存储的补码先转换成反码,后转换成原码,最后转换成十进制显示的。
int类型转换成为byte类型:
例一:int类型298转换成为byte类型
int a =298;
byte b = (byte)a;
298的原码:00000000 00000000 00000001 00101010 (B)
正数,因此补码与原码相同
转换为byte丢掉高位3个字节得到:
00101010 (B)
首位符号位为0,即为正数,因此补码与原码相同,转为十进制:
得b = 42 (D)
例二:int类型500转换成为byte类型
int a =500;
byte b = (byte)a;
500的原码:00000000 00000000 00000001 11110100 (B)
正数,因此补码与原码相同
转换为byte丢掉高位3个字节得到:
11110100 (B)
首位符号位为1,即为负数,由于负数按补码存储
11110100的原码:11110100 (B)
11110100的反码:10001011 (B)
11110100的补码:10001100 (B)
所以转换为byte之后的真值为 b = -12 (D)
例三:int类型-500转换成为byte类型
int a =-500;
byte b = (byte)a;
-500的原码:10000000 00000000 00000001 11110100 (B)
-500的反码:11111111 11111111 11111110 00001011 (B)
-500的补码:11111111 11111111 11111110 00001100 (B)
转换为byte丢掉高位3个字节得到:
00001100 (B)
首位符号位为0,即为正数,因此补码与原码相同,转为十进制得到:
得b = 12 (D)
例四:int类型-372转换成为byte类型
int a =-372;
byte b = (byte)a;
-372的原码:10000000 00000000 00000001 01110100 (B)
-372的反码:11111111 11111111 11111110 10001011 (B)
-372的补码:11111111 11111111 11111110 10001100 (B)
转换为byte丢掉高位3个字节得到:
10001100 (B)
首位符号位为1,即为负数,由于负数按补码存储:
11110100的原码:10001100 (B)
11110100的反码:11110011 (B)
11110100的补码:11110100 (B)
所以转换为byte之后的真值为 b = -116 (D)
附:补码原码的转换
1、正数的原码、补码相同;
2、附属原码和补码的转换:符号位不变,数值为按位去反后加一。