栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

解决Java中的强制类型转换和二进制表示问题

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

解决Java中的强制类型转换和二进制表示问题

1、Java中用补码形式表示

2、第一位正负位,1表示负,0表示正。

3、原码:一个数的二进制表示。

3的原码00000011   -3的 原码 100000114、反码:负数原码按位取反(符号位不变)。正数原码本身。

3的反码00000011   -3的反码111111005、补码:正数是原码本身。负数反码加1。

3的补码是00000011  -3的补码是11111101int占4个字节,32位

byte占1个字节,8位

所以强转时会截断。前24位

在内存中表示形式( 注意java中是以补码表示一个数,所以表示形式是补码,不是原码! ):

int a = 3 00000000 00000000 00000000 00000011 (强转byte时前面24个0被截断)
byte b = 3 00000011
int a = -3 11111111 11111111 11111111 11111101 (强转byte时前面24个1被截断)
byte b = -3 11111101

已知负数的补码,求负数:

补码-1=反码,反码按位取反=该负数绝对值

已知负数,求负数的补码:

1、负数原码除了符号位,按位取反(不含符号位),加1。

2、负数绝对值的补码(也就是原码),按位取反(含符号位),加1

例子:

java int 128转为byte,值:

128为正数,补码为10000000(前面24个0省略),变成byte,只剩下10000000(byte为1个字节),因为开头是1,所以为负数。即1个负数的补码是10000000。反码是01111111,原码是1000000。是128.因为是负数,所以是-128。

总结

以上所述是小编给大家介绍的解决Java中的强制类型转换和二进制表示问题,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/138239.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号