首页
学习
活动
专区
圈层
工具
发布
社区首页 >专栏 >原码反码补码的相互转换_补码转化为反码

原码反码补码的相互转换_补码转化为反码

作者头像
全栈程序员站长
发布2022-11-17 18:00:25
发布2022-11-17 18:00:25
1.4K0
举报

原码 反码 补码的相互转换

原码 反码 补码的转换 还是比较 简单基础的问题。之前学习java的时候就学过,后来忘记了,忘记了!!!,后来学了位移运算符,左移 右移 无符号右移 之后就由有点儿懵了。

原码,反码,补码 二进制中第一位是符号位,0表示正数,1表示负数。 以八位二进制数为例。

  1. 原码 十进制数正1的二进制原码 [+1] 原 = 0000 0001 十进制数负1的二进制原码 [-1] 原 = 1000 0001 第一位是符号位. 因为第一位是符号位, 所以 8位二进制数的取值范围:[1111 1111 , 0111 1111] 对应十进制 [-127 , 127] 范围。
  2. 反码 反码的表示方法是: 1.正数的反码是其本身 2.负数的反码是在其原码的基础上, 符号位不变,其余各个位取反. [+1] = [0000 0001]原 = [0000 0001]反 [-1] = [1000 0001]原 = [1111 1110] 反
  3. 补码 补码的表示方法是: 正数的补码就是其本身 负数的补码是在其原码的基础上, 符号位不变, 其余各位取反, 最后+1. (即在反码的基础上+1) [+1] = [0000 0001]原 = [0000 0001]反 = [0000 0001]补 [-1] = [1000 0001]原 = [1111 1110]反 = [1111 1111]补
  • 总结 在知道一个数原码的情况下: 正数:反码,补码 就是本身自己 负数:反码是高位符号位不变,其余位取反。补码:反码+1

练习 -A(二进制数)原码转为补码 ,先减一再按位取反 或者 先按位取反再加1 。 -A (二进制数)补码转化为原码 :按位取反加1 减一再按位取反 注意第一位符号位不变。 符号位就是第一位,1是负数,0是正数。 不表示数值的大小 例子: 问:4补码为:0100 -4补码为:1100 ? 答:-4原码是 1000 0100 ; 反码(原码符号位不变,按位取反)是1111 1011 ;补码(反码加一)是 1111 1100 八位二进制中(假设是八位的):4 补码为:0000 0100 -4补码为:1111 1100 详解: -4原码 转化为-4的补码过程 补码的转化 方法一: 1000 0100 减一 得1000 0011 按位取反得1111 1100 方法二 :1000 0100 按位取反得1111 1011 加一得 1111 1100 -4的补码转化为原码 按位取反但是符号位不变 方法一:1111 1100 按位取反 得 1000 0011 加一 0000 0100 取负数 得-4 方法二:1111 1100减一得 1111 1011 按位取反 1000 0100 取负数 得-4 记不住得话,记住,补码=原码按位取反再+1 ,原码=补码减一再按位取反 。 重点: 1.正数的,原码反码补码都相同。 以上规则是对于负数而言的。 2.正数与负数的原码 只差符号位的值,不一样 正数是0 负数是1 .

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

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/223083.html原文链接:https://javaforall.cn

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

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

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

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

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 原码 反码 补码的相互转换
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档