嵌入式硬件篇---原码、补码、反码


文章目录

  • 前言
  • 简介
  • 八进制原码、反码、补码
    • 1. 原码
      • 规则
      • 示例
      • 问题
    • 2. 反码
      • 规则
      • 示例
      • 问题
    • 3. 补码
      • 规则
      • 示例
      • 优点
    • 4. 补码的运算
    • 5. 总结
  • 十六进制原码、反码、补码
    • 1. 十六进制的基本概念
    • 2. 十六进制的原码
      • 规则
      • 示例
    • 3. 十六进制的反码
      • 规则
      • 示例
    • 4. 十六进制的补码
      • 规则
      • 示例
    • 5. 十六进制补码的运算
      • 示例:计算 5 + (-3)
    • 6. 十六进制补码的范围
    • 7. 总结
  • 总结


前言

以上就是今天要讲的内容,本文仅仅简单介绍了八进制、十六进制的原码、反码、补码。


简介

在计算机中,源码、补码和反码是表示有符号整数的三种方式,主要用于处理负数。下面详细介绍它们的概念和转换方法,并通过示例说明。

八进制原码、反码、补码

1. 原码

源码是最直观的表示方法,直接用最高位表示符号(0 表示正数,1 表示负数),其余位表示数值的绝对值

规则

正数:符号位为 0,数值部分为二进制绝对值

负数:符号位为 1,数值部分为二进制绝对值

示例

8 位二进制为例:

+5 的源码:00000101
-5 的源码:10000101

问题

  1. 源码的缺点是 0 有两种表示形式:00000000(+0)和 10000000(-0)。
  2. 加减法运算不方便,需要额外处理符号位。

2. 反码

反码是为了解决源码加减法的问题而提出的。正数的反码与源码相同负数的反码是对源码的数值部分逐位取反(符号位不变)

规则

正数:与源码相同。
负数:符号位为 1,数值部分逐位取反。

示例

+5 的反码:00000101(与源码相同)
-5 的反码:11111010(符号位不变,数值部分取反)

问题

  1. 反码仍然存在 +0 和 -0 的问题。
  2. 加减法运算时,最高位的进位需要循环加到最低位(称为“循环进位”),增加了复杂性。

3. 补码

补码是目前计算机中最常用的表示方法,解决了反码的问题。正数的补码与源码相同,负数的补码是对反码加 1。

规则

正数:与源码相同。
负数:符号位为 1,数值部分逐位取反后加 1。

示例

+5 的补码:00000101(与源码相同)

-5 的补码:
源码:10000101
反码:11111010
补码:11111011(反码加 1)

优点

  1. 0 只有一种表示形式:00000000。
  2. 加减法运算可以直接进行,无需额外处理符号位。
  3. 补码表示的范围比源码和反码更大。

4. 补码的运算

补码的最大优势是加减法可以直接用二进制运算完成。

示例:计算 5 + (-3)
5 的补码:00000101

-3 的补码:
源码:10000011
反码:11111100
补码:11111101

相加:

00000101 (5)
+11111101 (-3)


100000010
由于是 8 位二进制,最高位的进位被丢弃,结果为 00000010,即 2。

5. 总结

源码:直观,但加减法复杂
反码:解决了部分问题,但仍存在 +0 和 -0 的问题
补码:解决了所有问题,是现代计算机的标准表示方法。
通过补码,计算机可以高效地进行有符号整数的加减法运算,同时避免了符号处理的复杂性。

十六进制原码、反码、补码

1. 十六进制的基本概念

十六进制(Hexadecimal)使用 16 个符号表示数值:0-9 和 A-F(A=10, B=11, …, F=15)。

每个十六进制位对应 4 个二进制位。
例如,0x1A 表示二进制的 00011010。

2. 十六进制的原码

原码是数值的直接表示,最高位表示符号(0 为正,1 为负),其余位表示数值的绝对值。

规则

正数:符号位为 0,数值部分为十六进制绝对值。
负数:符号位为 1,数值部分为十六进制绝对值。

示例

假设使用 8 位十六进制数(32 位二进制),最高位为符号位:

+5 的原码:0x00000005
-5 的原码:0x80000005(最高位 8 表示符号位为 1)

3. 十六进制的反码

反码是为了解决原码加减法的问题而提出的。正数的反码与原码相同,负数的反码是对原码的数值部分逐位取反(符号位不变)。

规则

正数:与原码相同。
负数:符号位为 1,数值部分逐位取反。

示例

+5 的反码:0x00000005(与原码相同)
-5 的反码:
原码:0x80000005
数值部分取反:0x7FFFFFFA
因此,-5 的反码为:0x7FFFFFFA

4. 十六进制的补码

补码是目前计算机中最常用的表示方法,解决了反码的问题正数的补码与原码相同,负数的补码是对反码加 1。

规则

正数:与原码相同。
负数:符号位为 1,数值部分逐位取反后加 1。

示例

+5 的补码:0x00000005(与原码相同)
-5 的补码:
原码:0x80000005
反码:0x7FFFFFFA
补码:0x7FFFFFFB(反码加 1)

5. 十六进制补码的运算

补码的优势在于可以直接进行加减法运算,无需额外处理符号位。

示例:计算 5 + (-3)

5 的补码:0x00000005
-3 的补码:
原码:0x80000003
反码:0x7FFFFFFC
补码:0x7FFFFFFD

相加:

0x00000005 (5)
+0x7FFFFFFD (-3)


0x80000002
结果为 0x80000002,即 2。

6. 十六进制补码的范围

对于 32 位十六进制数(8 位十六进制):

正数范围:0x00000000 到 0x7FFFFFFF(0 到 2,147,483,647)
负数范围:0x80000000 到 0xFFFFFFFF(-2,147,483,648 到 -1)

7. 总结

原码:直接表示数值,最高位为符号位
反码:正数与原码相同,负数为原码数值部分取反
补码:正数与原码相同,负数为反码加 1
十六进制补码:与二进制补码的原理相同,只是用十六进制表示。
通过十六进制补码,计算机可以高效地进行有符号整数的加减法运算,同时避免了符号处理的复杂性。


总结

以上就是今天要讲的内容,本文仅仅简单介绍了八进制、十六进制的原码、反码、补码。

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

华中科技大学软件学院专硕怎样?

华中科技大学软件工程以顶尖的学科实力、扎实的产研融合和广阔的就业前景,持续吸引优质生源。尽管竞争激烈,但通过科学的备考规划与持续努力,完全可能实现名校梦想。建议26届考生锚定目标、拆分任务、善用华科开源社区资源(如HUST…

【EXCEL】【VBA】处理GI Log获得Surf格式的CONTOUR DATA

【EXCEL】【VBA】处理GI Log获得Surf格式的CONTOUR DATA data source1: BH coordination tabledata source2:BH layer tableprocess 1:Collect BH List To Layer Tableprocess 2:match Reduced Level from "Layer"+"BH"data source1: BH coordination…

1.【线性代数】——方程组的几何解释

1.方程组的几何解释 概述举例举例一1. matrix2.row picture3.column picture 概述 三种表示方法 matrixrow picturecolumn picture 举例 举例一 { 2 x − y 0 − x 2 y 3 \begin{cases} 2x - y 0 \\ -x 2y 3 \end{cases} {2x−y0−x2y3​ 1. matrix [ 2 − 1 − 1 2…

智慧机房解决方案(文末联系,领取整套资料,可做论文)

智慧机房解决方案-软件部分 一、方案概述 本智慧机房解决方案旨在通过硬件设备与软件系统的深度整合,实现机房的智能化管理与服务,提升机房管理人员的工作效率,优化机房运营效率,确保机房设备的安全稳定运行。软件部分包括机房管…

macbook2015升级最新MacOS 白苹果变黑苹果

原帖:https://www.bilibili.com/video/BV13V411c7xz/MAC OS系统发布了最新的Sonoma,超酷的动效锁屏壁纸,多样性的桌面小组件,但是也阉割了很多老款机型的升级权利,所以我们可以逆向操作,依旧把老款MAC设备强…

深度剖析责任链模式

一、责任链模式的本质:灵活可扩展的流水线处理 责任链模式(Chain of Responsibility Pattern)是行为型设计模式的代表,其核心思想是将请求的发送者与接收者解耦,允许多个对象都有机会处理请求。这种模式完美解决了以下…

业务开发 | 基础知识 | Maven 快速入门

Maven 快速入门 1.Maven 全面概述 Apache Maven 是一种软件项目管理和理解工具。基于项目对象模型的概念(POM),Maven 可以从中央信息中管理项目的构建,报告和文档。 2.Maven 基本功能 因此实际上 Maven 的基本功能就是作为 Ja…

使用 Apifox、Postman 测试 Dubbo 服务,Apache Dubbo OpenAPI 即将发布

作者:何亮,Apache Dubbo Contributor Apache Dubbo OpenAPI 简介 设计背景 在微服务体系中,RPC 服务的文档管理、测试、调用协作一直都是影响研发效能的关键一环,这些难题通常是由于 RPC 的特性所决定的:RPC 服务的…

2.11 sqlite3数据库【数据库的相关操作指令、函数】

练习: 将 epoll 服务器 客户端拿来用 客户端:写一个界面,里面有注册登录 服务器:处理注册和登录逻辑,注册的话将注册的账号密码写入数据库,登录的话查询数据库中是否存在账号,并验证密码是否正确…

C++模拟实现AVL树

目录 1.文章概括 2.AVL树概念 3.AVL树的性质 4.AVL树的插入 5.旋转控制 1.左单旋 2. 右单旋 3.左右双旋 4.右左双旋 6.全部代码 1.文章概括 本文适合理解平衡二叉树的读者阅读,因为AVL树是平衡二叉树的一种优化,其大部分实现逻辑与平衡二叉树是…

python-leetcode 25.环形链表

题目: 给定一个链表的头节点head,判断链表中是否有环。 如果链表中有某个节点,可以通过连续跟踪next指针再次到达,则链表中存在环。为了表示给定链表中的环,评测系统内部使用整数pos来表示链表尾连接到链表中的位置(…

从云原生到 AI 原生,谈谈我经历的网关发展历程和趋势

作者:谢吉宝(唐三) 编者按: 云原生 API 网关系列教程即将推出,欢迎文末查看教程内容。本文整理自阿里云智能集团资深技术专家,云原生产品线中间件负责人谢吉宝(唐三) 在云栖大会的精…

SQL Server安装流程

SQL Server 2022在安全性、可用性和性能方面不断创新,是现在最支持Azure的SQL Server版本。 SQL Server发展史 SQL Server的历史始于1989年,当时是由微软与Sybase合作的产品,旨在为Windows NT操作系统提供一个高性能的数据库解决方案。随着…

C# 上位机--变量

C# 上位机--变量 在 C# 上位机开发领域,变量是构建程序逻辑的基础元素之一。它就像是一个容器,用于存储各种类型的数据,从简单的数值到复杂的对象。正确理解和使用变量,对于开发出高效、稳定且易于维护的上位机程序至关重要。本文…

Vue3(1)

一.create-vue // new Vue() 创建一个应用实例 > createApp() // createRouter() createStore() // 将创建实例进行了封装,保证每个实例的独立封闭性import { createApp } from vue import App from ./App.vue// mount 设置挂载点 #app (id为app的盒子) createA…

Redis 数据类型 List 列表

列表类型是⽤来存储多个有序的字符串,如下图所⽰,a、b、c、d、e 五个元素从左到右组成了⼀个有序的列表,列表中的每个字符串称为元素(element),⼀个列表最多可以存储 2^32 - 1个元素。在 Redis 中&#xff…

yum报错 Could not resolve host: mirrorlist.centos.org

检查dns 使用ping www.baidu.com ,如果ping不通,检查/etc/resolv.conf文件中是否有: nameserver 8.8.8.8 nameserver 8.8.4.4 替换yum源 1.备份原始的 YUM 源配置文件: sudo cp /etc/yum.repos.d/CentOS-Base.repo /etc/yum.r…

STM32F103C8----外部中断探秘:解锁嵌入式实时响应的关键

​​​ 一、引言 在嵌入式系统的广袤世界里,中断就如同一位高效的调度员,发挥着举足轻重的作用。想象一下,一个嵌入式系统就像一个繁忙的工厂,CPU 如同工厂里的核心工人,负责执行各种任务。如果没有中断机制&#x…

分层解耦-IOC DI 入门

步骤 ①.Service层及 Dao层的实现类,交给I0C容器管理。 ②.为Controller及Service注入运行时,依赖的对象。 ③.运行测试。 添加注解进行分层耦合 Component 会将当前类交给IOC容器管理,成为IOC容器中的bean - 控制反转 Autowired 运行时,IOC容器…

SQL Server 逻辑查询处理阶段及其处理顺序

在 SQL Server 中,查询的执行并不是按照我们编写的 SQL 语句的顺序进行的。相反,SQL Server 有自己的一套逻辑处理顺序,这个顺序决定了查询的执行方式和结果集的生成。了解这些处理阶段和顺序对于优化查询性能和调试复杂查询非常重要。 SQL …