为了账号安全,请及时绑定邮箱和手机立即绑定

十进制数在内存中二进制数是如何得到的?

十进制数在内存中二进制数是如何得到的?

C
收到一只叮咚 2019-03-02 17:38:26
输出转换后的十进制数在内存中的每一位二进制数(共四个字节,每个字节以空格隔开)十进制数:122二进制数:00000000 00000000 00000000 00001100代码:for (int i = 31; i >= 0; i--){    std::cout << ((num >> i) & 0x1);//num 是十进制数     if (i % 8 == 0)     {        std::cout << ' ';     } }上面代码的是什么意思?可以详细解释一下吗?如果涉及到反码知识,也请详细解释一下?为什么这样就可以内存中的二进制数了,谢谢了!
查看完整描述

2 回答

?
回首忆惘然

TA贡献1847条经验 获得超11个赞

建议买本计算机原理课本从头学

查看完整回答
反对 回复 2019-03-02
?
九州编程

TA贡献1785条经验 获得超4个赞

其实代码好解释,num>>i代表将num的二进制数右移i位,给你个例子

例如num =1011也就是十进制的11,右移1位就是0101,右移20010,右移30001,这就是>>的意思

将移动的结果和0x1&运算,因为0x1相当于二进制的00...01,只有末尾有个1,所以那个for循环,相当于是取num的所有二进制位,例如第一次右移31位,也就是将最高位移动到了末尾,然后和1进行&,就相当于把最高位取出来了,然后右移动30位,相当于把次高位移动到了末尾,同理......然后打印出来,每打印8位,输出一个空格。


查看完整回答
反对 回复 2019-03-02
  • 2 回答
  • 0 关注
  • 541 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信