js位运算 源码 补码 反码

原码
一个数在计算机中是以二进制的形式存在的,其中第一位存放符号, 正数为 0, 负数为 1。原码就是用第一位存放符号的二进制数值。
例如 2 的原码为 00000010,-2 的原码为10000010。

反码
正数的反码是其本身。负数的反码是在其原码的基础上,符号位不变,其余各位取反,即 0变 1,1 变 0。
[+3]=[00000011]原=[00000011]反
[-3]=[10000011]原=[11111100]反
可见如果一个反码表示的是负数,并不能直观的看出它的数值,通常要将其转换成原码再计算。

补码
正数的补码是其本身。负数的补码是在其原码的基础上,符号位不变,其余各位取反,最后+1。(即负数的补码为在其反码的基础上+1)。
[+3]=[00000011]原=[00000011]反=[00000011]补
[-3]=[10000011]原=[11111100]反=[11111101]补
可见对于负数,补码的表示方式也是让人无法直观看出其数值的,通常也需要转换成原码再计算。

二进制与十进制的转换
二进制与十进制的区别在于数运算时是逢几进一位。二进制是逢 2 进一位,十进制也就是我们常用的 0-9 是逢 10 进一位

正整数的十进制转二进制
正整数的十进制转二进制的方法为将一个十进制数除以 2,得到的商再除以 2,以此类推直到商等于 1 或 0 时为止,倒取除得的余数,即为转换所得的二进制数的结果。
例如把 52 换算成二进制数,计算过程如下:
52 除以 2 得到的余数依次为:0、0、1、0、1、1,倒序排列,所以 52 对应的二进制数就是110100。

负整数的十进制转二进制
负整数的十进制转二进制为将该负整数对应的正整数先转换成二进制,然后对其“取反”,再对取反后的结果+1。即负整数采用其二进制补码的形式存储。
例如 -52 的原码为 10110100,其反码为 11001011,其补码为 11001100。所以 -52 转换为二进制后为 11001100。

十进制小数转二进制
十进制小数转二进制的方法为“乘 2 取整”,对十进制小数乘 2 得到的整数部分和小数部分,整数部分即是相应的二进制数码,再用 2 乘小数部分(之前乘

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值