大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。
Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺
注意:下面的例子都用有符号整数来举例
整数在数据中的储存
整数在数据中的储存方式是补码,所以如果要进行运算的话,那就需要将原码转换为补码再计算
正数的原反补的转换
正数的原码
原码就是把一个十进制的数转换为二进制的数字
比如:10的原码就是:1010
但是再内存中的储存是32bit,符号位是最高的一位,所以10的原码是
00000000000000000000000000001010(32bit)
符号位的描述如下,符号位0表示正数,1表示负数
正数的反码
正数的反码就是原码,不需要转化
正数的补码
正数的补码就是原码,同样不需要转换
所以正数在内存中的储存情况就是原码,因为正数的原码反码补码都一致。
负号的原反补的转换
负数的原码
如果是整数位(有符号整数)那么符号位就是1(不知道怎么来的话上面有图片),
然后其他的步骤和正数一样,只是符号位有区别
比如-10的原码就是
负数的反码
记住口诀就行:
符号位不变,其他位全部取反
还是以-10为例
负数的补码
还是以-10为例
口诀就是:反码+1
所以负数由十进制数字变成原码,再变成补码的全过程是
正数负数的补码变成原码
正数
不需要转换,补码就是原码
负数
就是将上面的步骤反着来
补码-1变成反码,然后
符号位不变,其他全部取反
发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/192551.html原文链接:https://javaforall.cn
【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛
【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...