关于二进制的原码,反码和补码的问题初步理解

在二进制里面,表现二进制有三种形式:1,:原码 2:反码3:补码

1:原码:就是二进制的最原始的表现,例如十进制的-2转化为二进制可以表示为10000000 00000000 00000000 00000010;(一个int有4个字节,每个字节有8个位,从而写成这样)。

2:反码:就是在原码的前提下,除了符号位(从左往右第一位)不变,其余的位按位取反,如上面的可以表示为:11111111 11111111 11111111 11111101

3:补码:就是在反码的前提下,在最后一位加1,那么上面的转为补码就是11111111 11111111 11111111 11111110


注意说明:1:计算机的运算是以补码方式进行的。

    2:正数的原码反码补码都是一样的。

    3:符号位0 表示正数,1表示负数。

    4: 0的反码补码都是0。

    5:查看结果,都是原码


常用的运算

    1:按位与(&):对比补码,都是1则取1,否则取0。

    2:按位或(|):对比补码,有1位1,无1取0。

    3:按位取反(~):对比补码,每一位都取反(上面的取反有前提条件)。

    4:与或:(^)对比补码,相同取1,不同取0。

    5:右移(>>),"移"就是去掉从右到左的位数,然后保证符号位不变。

    6:右移(<<),符号位不变,右位向左移动,低位补0.


在一般的情况下,考试都是计算负数的,而且一般是位运算,计算一个数简单,在一起就相对比较复杂了,虽然这个实际的编程开发中不是再怎么常用,但是,理解他还是对学习编程非常有帮助的。

    

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值