一篇文章让你搞懂原码,反码,补码!

news2025/1/24 14:54:26

目录

1.机器数和机器数真值

1.1机器数

1.2机器数的真值

2.原码,反码,补码的计算方法

2.1原码

2.2反码

2.3补码

3.为什么要使用反码和补码? 

3.1原码不能让符号位参与运算的问题: 

3.2为了解决原码作减法,引入反码

3.3为了解决0的符号问题,引入补码

4.深入反码和补码背后的意义

4.1钟表的例子 

4.2反码的定义:

4.3补码的定义:

4.4反码和补码计算方法的由来


1.机器数和机器数真值

1.1机器数

机器数是指计算机内部用来表示数值的二进制数。机器数通常包括符号位和数值位,其中符号位用于表示正负,数值位用于表示数的大小。计算机处理和存储数据时,使用的是机器数。

示例: 对于十进制数 +5 和 -5,其机器数表示如下(假设使用8位二进制表示):

  • +5:0000 0101
  • -5:1000 0101

1.2机器数的真值

机器数的真值是指该机器数在实际应用中的十进制值。真值可以通过机器数的符号位和数值位来确定。符号位为0表示正数,符号位为1表示负数。

示例:

  • 机器数 0000 0101 的真值是 +5
  • 机器数 1000 0101 的真值是 -5

2.原码,反码,补码的计算方法

原码,反码,补码等都是对机器数的存储形式,也即表示方法。

  • 机器数是一种广义的概念,指计算机中用二进制表示的数值。
  • 原码是一种具体的表示方法,用最高位表示符号,其余位表示数值。
  • 反码用于负数表示,负数的反码是其原码的数值位逐位取反。
  • 补码在计算机中广泛使用,负数的补码是其原码的数值位逐位取反后加1。

速记:

2.1原码

原码(Sign-Magnitude)是一种表示有符号数的方法。原码的最高位(符号位)表示数值的正负,其余位表示数值的大小。符号位为0表示正数,符号位为1表示负数。

示例: 对于十进制数 +5 和 -5,其原码表示如下(假设使用8位二进制表示):

  • +5:0000 0101
  • -5:1000 0101

2.2反码

反码(Ones' Complement)是一种表示负数的方法。正数的反码与其原码相同;负数的反码是将其原码的数值位逐位取反(即0变1,1变0),符号位保持不变。

示例: 对于十进制数 +5 和 -5,其反码表示如下(假设使用8位二进制表示):

  • +5:0000 0101
  • -5:1111 1010(先取原码1000 0101,然后数值位逐位取反)

2.3补码

补码(Two's Complement)是计算机中广泛使用的一种表示有符号数的方法。正数的补码与其原码相同;负数的补码是将其原码的数值位逐位取反后加1。补码的优点是加减运算可以统一处理,简化了计算过程。

示例: 对于十进制数 +5 和 -5,其补码表示如下(假设使用8位二进制表示):

  • +5:0000 0101
  • -5:1111 1011(先取原码1000 0101,然后数值位逐位取反得到1111 1010,再加1得到1111 1011)

3.为什么要使用反码和补码? 

3.1原码不能让符号位参与运算的问题: 

        现在我们知道了计算机可以有三种编码方式表示一个数,对于正数因为三种编码方式的结果都相同:

真值原码反码补码
[+1][0000 0001][0000 0001]反[0000 0001]补

        所以不需要过多解释,但是对于负数:

真值原码反码补码
[-1][1000 0001][1111 1110]反[1111 1111]补

        可见负数的原码,反码和补码是完全不同的。既然原码才是被人脑直接识别并用于计算表示方式,为何还会有反码和补码呢?

        首先, 因为人脑可以知道第一位是符号位,在计算的时候我们会根据符号位,选择对真值区域的加减。(真值的概念在本文最开头)

         但是对于计算机,要设计的尽量简单,计算机辨别"符号位"显然会让计算机的基础电路设计变得十分复杂!

        于是人们想出了将符号位也参与运算的方法。我们知道,根据运算法则减去一个正数等于加上一个负数,即:1-1 = 1 + (-1) = 0, 所以机器可以只有加法而没有减法,这样计算机运算的设计就更简单了。

于是人们开始探索将符号位参与运算,并且只保留加法的方法。

首先来看原码:

计算十进制的表达式: 1 - 1 = 0

1 - 1 = 1 + (-1) = [0000 0001]原+ [1000 0001]原= [1000 0010]原= -2

如果用原码表示,让符号位也参与计算,显然对于减法来说,结果是不正确的。这也就是为何计算机内部不使用原码表示一个数

3.2为了解决原码作减法,引入反码

计算十进制的表达式:1 - 1 = 0

1 - 1 

= 1 + (-1) 

= [0000 0001]原+ [1000 0001]原

= [0000 0001]反+ [1111 1110]反

= [1111 1111]反

= [1000 0000]原

= -0

        发现用反码计算减法,结果的真值部分是正确的。而唯一的问题其实就出现在"0"这个特殊的数值上,虽然人们理解上+0和-0是一样的,但是0带符号是没有任何意义的,而且会有[0000 0000]原和[1000 0000]原两个编码表示0。

3.3为了解决0的符号问题,引入补码

1-1 

= 1 + (-1) 

= [0000 0001]原+ [1000 0001]原

= [0000 0001]补+ [1111 1111]补

= [1 0000 0000]补 【注意:进位1不在计算机字长里。】

= [0000 0000]补

= [0000 0000]原 

= 0

这样0用[0000 0000]表示,而以前出现问题的-0则不存在了。而且可以用[1000 0000]表示-128:-128的由来如下:

(-1) + (-127) 

= [1000 0001]原+ [1111 1111]原

= [1111 1111]补+ [1000 0001]补

= [1000 0000]补

-1-127的结果应该是-128,在用补码运算的结果中,[1000 0000]补就是-128,但是注意因为实际上是使用以前的-0的补码来表示-128,所以-128并没有原码和反码表示。

(对-128的补码表示[1000 0000]补,算出来的原码是[0000 0000]原,这是不正确的)

使用补码,不仅仅修复了0的符号以及存在两个编码的问题,而且还能够多表示一个最低数。这就是为什么8位二进制,使用原码或反码表示的范围为[-127, +127],而使用补码表示的范围为[-128, +127]。

因为机器使用补码,所以对于编程中常用到的有符号的32位int类型,可以表示范围是: [-231, 231-1] 因为第一位表示的是符号位,而使用补码表示时又可以多保存一个最小值。

4.深入反码和补码背后的意义

4.1钟表的例子 

假设需要将钟表从六点调到三点:有两种方式

1.时针逆时针往前拨三格;

 

2.时针顺时针往后拨九格。 

 

钟表就是一个会回绕的一位十二进制的计算系统:

从1数到12后又会从1开始从头数到12。

如上我们想计算 6-3 = 3的时候可以通过 6 + (12-3) = 3而得出结果;

我们说在这个计算系统中3和9是关于12互补的,也即是3关于12的补数是9,在计算

一个数减去一个数时,可以通过一个数加上这个数的补数来同样得出结果。

这种现象同样在二级制的N位计算机系统中存在。

4.2反码的定义:

反码(Ones' Complement)的本质

        英文名字:Ones' Complement ,对一个数关于 "1" 进行求补码。这个 "1" 本质上是一个有限位计数系统里所能表示的最大值。以下是具体解释:

有限位计数系统中的最大值

在不同的进制和位数的系统中,最大值不同:

  • 8 位二进制中的最大值是 1111 1111(255)。
  • 1 位十进制中的最大值是 9
  • 3 位十六进制中的最大值是 FFF(4095)。

反码的性质

反码的构造方式使得以下性质成立:

  • 一个正数的反码与其原码相同。
  • 一个负数的反码加上它的原码的绝对值等于 2^n-1(也就是该计算系统中能表示的最大值)。

数学表示

反码的计算可以表示为:

[x]反 = ( M − |x| )

其中,M 是系统中的最大值。例如,在 8 位二进制系统中,M = 255(即 1111 1111)。

关于最大值对一个数求补

反码实际上是通过对最大值减去一个数来得到:

  • 在 8 位二进制中,最大值是 1111 1111。对一个数 x 求反码就是用 1111 1111 减去 x的绝对值
  • 结果体现的是将 x 的数值位每一位取反,即 0110

 

按位取反

这种减法操作在二进制系统中直接体现为按位取反:

  • 例如,x = 0000 0101(十进制的 5)
  • 反码为 1111 1010(十进制的 250,即 255 - 5

        总的来说,在开头讲的反码的计算方法只是求一个二进制数的反码在具体计算时的具体体现而已。 而这种减法得出的结果是将原码的数值位按位取反的体现也是反码名字的由来。

4.3补码的定义:

        英文名字: Two's Complement,对一个数关于“二”求补,这个二指的是一个N位计算系统的容量也即2^N,也叫做模。

计数系统的容量(模)

计数系统的容量(模)是指系统所能表示的所有不同状态的总数。例如:

  • 对于 4 位二进制数(不考虑符号),其容量是 24=162^4 = 1624=16。
  • 对于 1 位符号位和 4 位数值位,总共 5 位二进制数,容量是 25=322^5 = 3225=32。

补码的性质

补码的构造方式使得以下性质成立:

  • 一个正数的补码与其原码相同。
  • 一个负数的补码加上它的原码的绝对值等于 2^n(也就是该计算系统的模)。

补码的计算公式

补码的计算公式为:

[x]补 = (模 - |x|)

其中,模是计数系统的容量。例如,对于 4 位二进制数,模是 16

为什么补码可以让有符号数直接做加法

补码的一个核心特点是,它将减法运算转换成了加法运算。具体来说,对于一个 n 位二进制数系统,给定两个有符号整数 x 和 y,x - y 可以通过 x + (-y) 来实现,其中 -y 是 y 的补码。

补码系统中的“回绕”

在补码系统中,4 位二进制数的范围是从 0000 到 1111。当结果超过 1111(或小于 0000)时,它会自动回绕。例如:

  • 1111 (补码 -1) 加 1 得到 0000(补码 0),这就像钟表从 11 点走到 12 点,然后重新开始。
  • 0000 (补码 0) 减 1 得到 1111(补码 -1),这就像钟表从 12 点走到 11 点。

下面通过一个四位二进制计算系统来举例:

所有码值作为补码代表的数
00000
00011
00102
00113
01004
01015
01106
01117
1000-8
1001-7
1010-6
1011-5
1100-4
1101-3
1110-2
1111-1

该计算系统可以类比于一个会回绕的钟表:

假如现在要计算4-2的值:

4 - 2 = 4 + (-2) = 2

减去一个数等于加上这个数的补码

[0100]补 + [1110]补 =[10010]补

溢出一位,我们不管,系统自动回绕:

[0010]补表示的就是2,可见结果正确。

该过程在图上可以表示为:

而像这种为了弥补反码中零的两种表示方式的漏洞,正是补码名字的由来。

4.4反码和补码计算方法的由来

       总体来讲,反码和补码都是利用一个计算系统在不断的累加之后会出现回绕的现象用来正确处理加法的溢位,这样只要不超出该计算系统所表是数值的范围的运算就可以通过这个计算系统来计算相应的加减法。

在一个n位的二进制计算系统中; 

        对于求反码:

[x]反 = (2^n - 1) - |x|

        具体计算时的体现就是数值位按位取反;

        对于求补码:

[x]补 = 2^n - |x|

联立二式,就可以推出,补码是原码数值位按位取反后的结果加上1,同时也是反码加1。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1977879.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【C语言】算法:二分查找

当我们想在一个有序的序列里面查找一个数字的时候&#xff0c;通常会想到使用循环遍历&#xff0c;也就是下面这种方法&#xff1a; 比如我们想在下面的数组里面找到7&#xff1a; int main() {int num 7;int arr[10] { 1,2,3,4,5,6,7,8,9,10 };for (int i 0; i < size…

在亚马逊云科技AWS上利用ElasticSearch和RAG搭建个性化推荐系统

简介&#xff1a; 小李哥将继续每天介绍一个基于亚马逊云科技AWS云计算平台的全球前沿AI技术解决方案&#xff0c;帮助大家快速了解国际上最热门的云计算平台亚马逊云科技AWS AI最佳实践&#xff0c;并应用到自己的日常工作里。 本次介绍用当下热门的RAG和大语言模型&#xf…

ThreadLocal源码分析

1.前言 1.1 ThreadLocal基本原理 ThreadLocal 是 Java 中的一个非常有用的类&#xff0c;它提供了一种线程局部变量&#xff0c;即每个线程都可以访问到自己独立初始化过的变量副本&#xff0c;这个变量对其他线程是不可见的。最常见的用法就是用户请求携带用户ID请求某个接口…

机器学习 第9章-聚类

机器学习 第9章-聚类 9.1 聚类任务 在“无监督学习”(unsupervised learning)中&#xff0c;训练样本的标记信息是未知的&#xff0c;目标是通过对无标记训练样本的学习来揭示数据的内在性质及规律&#xff0c;为进一步的数据分析提供基础。此类学习任务中研究最多、应用最广…

【Git】如何优雅地使用Git中的tag来管理项目版本

目录 tagtag 和 branch区别操作命令打tag&#xff0c;当前分支标记tag提交到远程服务器删除本地tag删除远程tag切换到特定的tag查看所有tag查看标签详细信息 好书推荐 tag Git中的tag&#xff08;标签&#xff09;用于给项目在特定时间点&#xff08;某个版本发布&#xff09;…

周鸿祎回应将成三六零第一大股东:会和公司一起走下去

在数字化浪潮席卷全球的今天&#xff0c;网络安全已成为国家安全的重要组成部分。三六零&#xff0c;作为国内网络安全领域的佼佼者&#xff0c;其每一步动态都牵动着业界的神经。近日&#xff0c;随着公司控股股东天津奇信志成的解散清算&#xff0c;周鸿祎的持股比例上升&…

【数据泄露】据称一名威胁行为者正在出售某个加密货币交易平台数据库

该威胁行为者表示&#xff1a; “你好&#xff0c; 我想出售一个加密货币交易平台的数据库 (.csv)。该平台很活跃&#xff0c;并且对实际使用它的用户来说很合法。 行数&#xff1a;150,000 价格&#xff1a;1,500 美元” 泄露数据&#xff1a;user_id、user_name、user_ro…

【Java】Java学生信息管理系统(源码)【独一无二】

&#x1f449;博__主&#x1f448;&#xff1a;米码收割机 &#x1f449;技__能&#x1f448;&#xff1a;C/Python语言 &#x1f449;公众号&#x1f448;&#xff1a;测试开发自动化【获取源码商业合作】 &#x1f449;荣__誉&#x1f448;&#xff1a;阿里云博客专家博主、5…

SpringBoot项目详细整合邮箱服务

springboot 版本&#xff1a;2.6.3 Java版本&#xff1a;1.8 一、应用场景 用户注册发送激活邮箱 注册登录时用邮箱接收验证码 用户密码重置 向用户发送相关系统消息 … 二、添加依赖 <!-- 邮箱 --> <dependency><groupId>org.springframework.b…

【单片机毕业设计选题24098】-校园智能绿植浇灌系统

系统功能: 1. 手机通过蓝牙模块显示系统信息 2. OLED模块显示系统信息 3. DHT11采集温湿度 4. 继电器模块控制水泵 5. 按键调节湿度设定阈值 6. 土壤湿度传感器模块采集土壤湿度 7. 光照传感器采集光照值 系统分为手动和自动模式&#xff0c;上电默认为自动模式&#x…

scratch魔法门 2024年6月scratch四级 中国电子学会图形化编程 少儿编程等级考试四级真题和答案解析

目录 scratch魔法门 一、题目要求 1、准备工作 2、功能实现 二、案例分析 1、角色分析 2、背景分析 3、前期准备 三、解题思路 1、思路分析 2、详细过程 四、程序编写 五、考点分析 六、推荐资料 1、入门基础 2、蓝桥杯比赛 3、考级资料 4、视频课程 5、pyt…

2024/8/4 维高-STD60N驱动器(伺服)---客户反馈:电机异响

步进电机 MHS1A86-60B85B &#xff0c;额定电流6A 步骤一&#xff1a;设置额定电流 std60n驱动器拔码全部为off&#xff08;后台设置&#xff09;&#xff0c;伺服后台连上后设置h00-11按电机铭牌进行 设置下额定电流 步骤二&#xff1a;最好设置峰值电流一…

Jenkins未授权访问漏洞

Jenkins未授权访问漏洞 默认情况下 Jenkins面板中用户可以选择执行脚本界面来操作一些系统层命令&#xff0c;攻击者可通过未授权访问漏洞或者暴力破解用户密码等进入后台管理服务&#xff0c;通过脚本执行界面从而获取服务器权限。 漏洞复现 步骤一:使用以下fofa语法进行产品…

GUI:Tkinter(一)

Tkinter文档 一&#xff0c;Tkinter基本流程 1. 创建应用程序主窗口对象 from tkinter import * window Tk() window.mainloop()#开启主循环 2. 在主窗口中&#xff0c;添加各种可视化组件&#xff0c;比如&#xff1a;按钮&#xff08;Button&#xff09;、文本框&#x…

Java中Lambda表达式的使用

Lambda的背景 Lambda表达式是Java SE 8中一个重要的新特性。lambda表达式允许你通过表达式来代替功能接口。 lambda表达式就和方法一样,它提供了一个正常的参数列表和一个使用这些参数的主体(body,可以是一个表达式或一个代码块)。 Lambda 表达式&#xff08;Lambda expressio…

用户看广告获取密码访问网页内容流量主模式源码

简介&#xff1a; 全开源付费进群流量主模式&#xff0c;用户看广告获取密码访问网页内容&#xff0c;网站生成内容&#xff0c;用户需要浏览内容跳转至小程序&#xff0c;观看广告后获取密码&#xff0c;输入密码查看网页内容。 与之前得9.9付费进群区别就是内容体现在了网页…

【信创】国产操作系统上使用的万能打印驱动 _ 统信 _ 麒麟 _ 中科方德

往期好文&#xff1a;统信UOS服务器离线安装postgresql数据库 Hello&#xff0c;大家好&#xff01;今天给大家带来一款在信创终端操作系统上使用的万能打印驱动——瑞印万能打印驱动。这款驱动程序是国产操作系统下的通用打印驱动程序&#xff0c;具有很高的兼容性和广泛的功能…

图论:1857. 有向图中最大颜色值(拓扑排序+动态规划)

文章目录 1.问题分析2.代码解析2.1 代码步骤1. 初始化数据结构2. 构建图和入度数组3. 初始化队列4. 拓扑排序和动态规划5. 检查是否存在环并返回结果 3. 问题扩展1. 最长路径问题&#xff08;DAG&#xff09;2. 最短路径问题&#xff08;DAG&#xff09;3. 最大路径和问题4. 路…

科普文:微服务之Spring Cloud 客户端负载均衡组件LoadBalancer替代Ribbon

概叙 负载均衡 负载均衡的两个基本点&#xff1a; 选择哪个服务器来处理客户端请求。将客户端请求转发出去。 一个核心原理&#xff1a;通过硬件或软件的方式维护一个服务列表清单。当用户发送请求时&#xff0c;会将请求发送给负载均衡器&#xff0c;然后根据负载均衡算法从…

中仕公考:2024年重庆市属事业单位招聘公告

本次公开招聘市属事业单位工作人员218名&#xff0c;报考者可登录重庆市人力资源和社会保障局官网“事业单位公开招聘”栏查阅。 (一)可报考的条件 1.具有中华人民共和国国籍; 2.遵守中华人民共和国宪法和法律&#xff0c;具有良好的品行; 3.身体健康&#xff0c;符合事业单…