32767+1=-32768 补码

问题:

16位的int

int a = 32767;

std::count << a + 1 << std::endl;

涉及到数值二进制的存储形式,有三种,原码,反码,补码

一个数在计算机中的二进制表示形式,  叫做这个数的机器数。机器数是带符号的,在计算机用一个数的最高位存放符号,正数为0,负数为1。因为第一位是符号位,所以机器数的形式值就不等于真正的数值。例如字长八位的有符号数 10000011,形式值131≠真值-3。为区别起见,将带符号位的机器数对应的真正数值称为机器数的真值

对于一个数,计算机要使用一定的编码方式进行存储。原码,反码,补码是机器存储一个具体数字的编码方式

在程序进行数值计算的时候,使用数值的补码进行运算(内存中表现形式),然后使用计算结果的原码进行显示

原码:把最高位当作符号位,0表示正数,1表示负数,数值0的原码是0000 0000,而字长八位的1111 1111表示为-127,规定1000 0000表示为-128。字长16位的 1000 0000 0000 0000用来表示 -32768

正数的反码和原码一样,负数的反码是原码除符号位以外,每一位取反

正数的补码和原码一样,负数的补码是反码+1

所以,

32767的原码:0111 1

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值