当前位置: 首页 > news >正文

原码、反码、补码极简理解

原码、反码、补码

1、概述
  • 计算机里都是以补码的形式存储数据,单纯给我们补码形式的数据,我们是不认识的,只有把补码转换成原码,我们才能知道这份数据的意思
2、基本介绍
  1. 原码:最高位为符号位,0 代表正数,1 代表负数,非符号位为该数字绝对值的二进制

  2. 反码:正数的反码与原码一致,负数的反码是对原码按位取反,只是最高位(符号位)不变

  3. 补码:正数的补码与原码一致,负数的补码是该数的反码加 1

  • 这里以一个字节(8 位)为例
-5-5
原码0000 01011000 0101
反码0000 01011111 1010
补码0000 01011111 1011
3、为什么需要三码
  • CPU 里面有加法器,即可以计算 5 + 5,但是它里面没有减法器,即无法计算 5 -5,但是可以将他转换一下 5 + (-5)
源码反码补码
计算结果0000 0101
1000 0101
—————
1000 1010
-10
0000 0101
1111 1010
—————
1000 0000
-0
0000 0101
1111 1011
————
1 0000 0000
0000 0000
0
  1. 通过原码计算,结果错误

  2. 通过反码计算,得到 1000 0000,即 -0,即 0,但是 0000 0000 也是 0,不能有两种不同的形式来表示 0(无论是二进制还是十进制)

  3. 通过补码计算,得到了 9 位,去掉最高位,得到结果正确


http://www.mrgr.cn/news/44159.html

相关文章:

  • 怎么避免在pod产生-派生炸弹(Fork Bomb)? k8s(kubernetes)
  • 漫谈前端:2025年框架是该选vue还是react?
  • Spring Boot 面向切面编程(AOP) 入门
  • 【C++驾轻就熟】vector深入了解及模拟实现
  • 【动态规划-最长公共子序列(LCS)】力扣1035. 不相交的线
  • LeetCode Hot100 | Day1 | 二叉树:二叉树的直径
  • 本田汽车投资SiLC Technologies:携手共促自动驾驶技术新飞跃
  • 网站集群批量管理-Ansible-模块管理
  • 贪心算法相关知识
  • Linux下网络转发功能
  • Codeforces Round 977 (Div. 2) C2 Adjust The Presentation (Hard Version)(思维,set)
  • 老房翻新,弱配电箱需不需要加?
  • 【Rust练习】17.泛型
  • 音质好且平价的开放式耳机排行榜10强?分享值得安利的蓝牙耳机
  • 留存率的定义与SQL实现
  • 物理学基础精解【56】
  • 新机配置Win11
  • Vue入门-指令学习-v-else和v-else-if
  • jsencrypt实现js加密的另外一种方式(使用node-jsencrypt库)
  • 【AI知识点】归一化(Normalization)