「Java学习笔记」 1、int与byte之间的转换问题

基本概念:在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、附属原码和补码的转换:符号位不变,数值为按位去反后加一。

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值