首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >反码补码原码转换c语言程序_127的原码反码补码

反码补码原码转换c语言程序_127的原码反码补码

作者头像
全栈程序员站长
发布2022-09-30 19:28:27
发布2022-09-30 19:28:27
1.3K0
举报

大家好,又见面了,我是你们的朋友全栈君。

注意:下面的例子都用有符号整数来举例

整数在数据中的储存

整数在数据中的储存方式是补码,所以如果要进行运算的话,那就需要将原码转换为补码再计算

正数的原反补的转换

正数的原码

原码就是把一个十进制的数转换为二进制的数字 比如:10的原码就是:1010 但是再内存中的储存是32bit,符号位是最高的一位,所以10的原码是 00000000000000000000000000001010(32bit)

符号位的描述如下,符号位0表示正数,1表示负数

正数的反码

正数的反码就是原码,不需要转化

正数的补码

正数的补码就是原码,同样不需要转换

所以正数在内存中的储存情况就是原码,因为正数的原码反码补码都一致。

负号的原反补的转换

负数的原码

如果是整数位(有符号整数)那么符号位就是1(不知道怎么来的话上面有图片), 然后其他的步骤和正数一样,只是符号位有区别 比如-10的原码就是

负数的反码

记住口诀就行: 符号位不变,其他位全部取反

还是以-10为例

负数的补码

还是以-10为例

口诀就是:反码+1

所以负数由十进制数字变成原码,再变成补码的全过程是

正数负数的补码变成原码

正数

不需要转换,补码就是原码

负数

就是将上面的步骤反着来 补码-1变成反码,然后 符号位不变,其他全部取反

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/192551.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年9月17日 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 整数在数据中的储存
  • 正数的原反补的转换
    • 正数的原码
    • 正数的反码
    • 正数的补码
  • 负号的原反补的转换
    • 负数的原码
    • 负数的反码
    • 负数的补码
  • 正数负数的补码变成原码
    • 正数
    • 负数
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档