计算机组成原理之数据的表示和运算(一)

news2025/1/24 17:35:27

目录

  • 一、引言
  • 二、进位计数制
    • 2.1 十进制计数法
    • 2.2 二进制
    • 2.3 八进制
    • 2.4 十六进制
    • 2.5 进制转换:二进制、八进制、十六进制、十进制之间的转换
      • 2.5.1 任意进制到十进制转换
      • 2.5.2 二进制与八进制和十六进制如何进行互相转换?
      • 2.5.3 十进制到任意进制的转换
    • 2.6 真值和机器数
    • 2.7 小结
  • 三、BCD 码
  • 四、无符号整数的表示和运算
    • 4.1 无符号整数在计算机中的应用
    • 4.2 无符号整数的表示
    • 4.3 无符号整数的加法运算
    • 4.4 无符号整数的减法运算
    • 4.5 小结
  • 五、带符号整数的表示和运算_原码、反码、补码
    • 5.1 带符号整数在计算机中的应用
    • 5.2 带符号整数的表示
    • 5.3 小结
    • 5.4 补充:原码、反码、补码的特性对比
    • 5.5 移码

在正式的学习 C 语言之前,我们需要先了解计算机组成原理相关的知识。

一、引言

现代计算机的结构如下图所示:

数据如何在计算机中表示?运算器如何实现数据的算术、逻辑运算?

二、进位计数制

本小节内容大致如下:

最古老的计数方法:

2.1 十进制计数法

在这里插入图片描述
补充说明:

我们平时使用的数字都是由 0~9 共十个数字组成的,例如 1、6、10、297、952 等,一个数字最多能表示九,如果要表示十、十一、二十九、一百等,就需要多个数字组合起来。例如表示 5+8 的结果,一个数字不够,只能 进位,用 13 来表示;这时 进一位 相当于十,进两位 相当于二十。因为逢十进一(满十进一),也因为只有 0~9 共十个数字,所以叫做 十进制(Decimalism)。 十进制是在人类社会发展过程中自然形成的,它符合人们的思维习惯,例如人类有十根手指,也有十根脚趾。进制也就是进位制。进行加法运算时 逢X进一(满X进一),进行减法运算时 借一当X,这就是X进制,这种进制也就包含X个数字,基数为X。十进制有 0~9 共10个数字,基数为10,在加减法运算中,逢十进一,借一当十。

推广:r进制计数法,如下图所示:
在这里插入图片描述

2.2 二进制

我们不妨将思维拓展一下,既然可以用 0~9 共十个数字来表示数值,那么也可以用 0,1 两个数字来表示数值,这就是 二进制(Binary)。 例如,数字 0,1,10,111,100,1000001 都是有效的二进制。在计算机系统内部,所有的信息都是用二进制进行编码的,这样做的原因有以下几点:

① 二进制只有两种状态,使用有两个稳定状态的物理器件就可以表示二进制的每一位,制造成本比较低,例如用高低电平或电荷的正负极性都可以很方便地表示 0和1
② 二进制位 1和0 正好与逻辑值 真和假 对应,为计算机实现逻辑运算和程序中的逻辑判断提供了便利条件。
③ 二进制的编码和运算规则都很简单,通过逻辑门电路能方便地实现算术运算。二进制是学习编程必须掌握的基础

二进制加减法和十进制加减法的思想是类似的:

对于十进制,进行加法运算时逢十进一,进行减法运算时借一当十
对于二进制,进行加法运算时逢二进一,进行减法运算时借一当二

下面两张示意图详细演示了二进制加减法的运算过程。二进制加法:

1+0=1、1+1=10、11+10=101、111+111=1110

演示如下图所示:
在这里插入图片描述
二进制减法:

1-0=1、10-1=1、101-11=10、1100-111=101

演示如下图所示:
在这里插入图片描述

2.3 八进制

八进制有 0~78个 数字,基数为8,加法运算时 逢八进一,减法运算时 借一当八。例如,数字 0,1,5,7,14,733,67001,25430 都是有效的八进制。八进制加法:

3+4=7、5+6=13、75+42=137、2427+567=3216

演示如下图所示:
在这里插入图片描述
八进制减法:

6-4=2、52-27=23、307-141=146、7430-1451=5757

演示如下图所示:
在这里插入图片描述

2.4 十六进制

除了二进制和八进制,十六进制也经常使用,甚至比八进制还要频繁。十六进制中,用 A 来表示 10B 表示 11C 表示 12D 表示 13E 表示 14F 表示 15,因此有 0~F16 个数字,基数为 16,加法运算时 逢16进1,减法运算时 借1当16。例如,数字 0,1,6,9,A,D,F,419,EA32,80A3,BC00 都是有效的十六进制。

注意,十六进制中的字母不区分大小写,ABCDEF 也可以写作 abcdef

十六进制加法:

6+7=D、18+BA=D2、595+792=D27、2F87+F8A=3F11

演示如下图所示:
在这里插入图片描述
十六进制减法:

D-3=A、52-2F=23、E07-141=CC6、7CA0-1CB1=5FEF

演示如下图所示:
在这里插入图片描述

2.5 进制转换:二进制、八进制、十六进制、十进制之间的转换

2.5.1 任意进制到十进制转换

在这里插入图片描述
更多转换成十进制的例子:

二进制:1001 = 1×23 + 0×22 + 0×21+ 1×20 = 8 + 0 + 0 + 1 = 9(十进制)
二进制:101.1001 = 1×22 + 0×21 + 1×20 + 1×2-1 + 0×2-2 + 0×2-3 + 1×2-4 = 4 + 0 + 1 + 0.5 + 0 + 0 + 0.0625 = 5.5625(十进制)
八进制:302 = 3×82 + 0×81 + 2×80 = 192 + 0 + 2 = 194(十进制)
八进制:302.46 = 3×82 + 0×81 + 2×80 + 4×8-1 + 6×8-2 = 192 + 0 + 2 + 0.5 + 0.09375= 194.59375(十进制)
十六进制:EA7 = 14×162 + 10×161 + 7×160 = 3751(十进制)

2.5.2 二进制与八进制和十六进制如何进行互相转换?

**各种进制常见的书写方式:**

2.5.3 十进制到任意进制的转换

整数部分:

小数部分:

十进制到二进制拼凑法:
在这里插入图片描述

2.6 真值和机器数

在这里插入图片描述

2.7 小结

在这里插入图片描述
中国古代的二进制系统:
在这里插入图片描述

三、BCD 码

8421 码操作如下:

注: 若相加结果在合法范围内,则无需修正。 其余码:

小结:

四、无符号整数的表示和运算

4.1 无符号整数在计算机中的应用

4.2 无符号整数的表示

实例:

4.3 无符号整数的加法运算

4.4 无符号整数的减法运算

具体实现过程:① 全部位按位取反,末位+1

② 减法变加法:

4.5 小结

五、带符号整数的表示和运算_原码、反码、补码

本小节总览:

5.1 带符号整数在计算机中的应用

5.2 带符号整数的表示

原码表示法:

原码的缺点:

原码–>反码–>补码的转换(机算)

原码、补码快速转换技巧(手算)

补码的加法运算(例1):

补码的加法运算(例2):

补码的减法运算:

补码的减法运算(例3):

5.3 小结

5.4 补充:原码、反码、补码的特性对比

各种码的基本特性总结:

5.5 移码

特点:

各种码的基本特性总结(补充):

用几种码表示整数:

练习:

至此今天的学习就到此结束了,笔者在这里声明,笔者写文章只是为了学习交流,以及让更多学习C语言的读者少走一些弯路,节省时间,并不用做其他用途,如有侵权,联系博主删除即可。感谢您阅读本篇博文,希望本文能成为您编程路上的领航者。祝您阅读愉快!


在这里插入图片描述

    好书不厌读百回,熟读课思子自知。而我想要成为全场最靓的仔,就必须坚持通过学习来获取更多知识,用知识改变命运,用博客见证成长,用行动证明我在努力。
    如果我的博客对你有帮助、如果你喜欢我的博客内容,请 点赞评论收藏 一键三连哦!听说点赞的人运气不会太差,每一天都会元气满满呦!如果实在要白嫖的话,那祝你开心每一天,欢迎常来我博客看看。
 编码不易,大家的支持就是我坚持下去的动力。点赞后不要忘了 关注 我哦!

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

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

相关文章

layui框架学习(42:文件上传模块-上)

之前学习asp.net core编程入门教程时结合layui测试过文件上传《基于ASP.Net Core和Layui的多文件上传》,但没有认真学习过layui的文件上传模块,本文开始,计划分两章学习并记录文件上传模块中的属性、事件及函数的使用方法。   layui中的文件…

1.1 数据库系统简介

1.1.数据库系统简介 前言: 数据库系统是一个软件系统,用于管理和操作数据库。它提供了一个组织良好、高效并能够方便存取的数据存储机制,并且能够支持各种数据操作、事务管理、并发控制和恢复功能。以下是数据库系统的一些主要特点和组件&a…

redis缓存雪崩、穿透、击穿解决方案

redis缓存雪崩、穿透、击穿解决方案 背景缓存雪崩缓存击穿缓存穿透总结背景 关于缓存异常,我们常见的有三个问题:缓存雪崩、缓存击穿、缓存穿透。这三个问题一旦发生,会导致大量请求直接落到数据库层面。如果请求的并发量很大,会影响数据库的运行,严重的会导致数据库宕机…

xsschallenge1~13通关详细教程

文章目录 XSS 挑战靶场通关level1level2level3level4level5level6level7level8level9level10level11level12level13 XSS 挑战靶场通关 level1 通过观察发现这个用户信息可以修改 那么我们直接输入攻击代码 <script>alert(/wuhu/)</script>弹框如下&#xff1a; …

烟花厂人员作业释放静电行为检测算法

烟花厂人员作业释放静电行为检测算法通过pythonyolo系列算法模型框架&#xff0c;烟花厂人员作业释放静电行为检测算法在工厂车间入口处能够及时捕捉到人员是否触摸静电释放仪。一旦检测到人员进入时没有触摸静电释放仪&#xff0c;系统将自动触发告警。Python是一种由Guido va…

第 1 章 绪论(计算多项式)

示例代码 1&#xff1a; /* 计算 1 - 1 / x 1 / x * x - ... */#include <stdio.h> #include <sys/timeb.h>int main(void) {double x;int n;printf("Please input x and n: ");scanf_s("%lf%d", &x, &n);struct timeb t1;ftime(&…

2023.8.27 关于 Junit5 详解

目录 引言 注解 断言 用例的执行顺序 参数化 测试套件 引言 Junit 是一个基于Java语言的单元测试框架Selenium 是一个用于Web应用程序测试的自动化测试框架结合二者能让我们的 Web自动化测试 更加完善和全面 注意&#xff1a; 本文所讲的内容&#xff0c;均基于以下依…

机器视觉工程师永不为奴,他们是肯干肯出差肯加班肯拼命肯被使唤肯被叼

​ 永不为奴&#xff0c;为什么这样呐喊&#xff0c;真的很难做到。我们职业机器视觉工程师&#xff0c;本身职业具有一大特点就是专业性。 但是我们机器视觉工程师是专业技术绝不苟同于不是技术人员言语&#xff0c;我们很专业。 肯出差&#xff1a; 设备去那里&#xff0c;…

启莱OA CloseMsg.aspx SQL注入

子贡曰&#xff1a;“贫而无谄&#xff0c;富而无骄&#xff0c;何如&#xff1f;”子曰&#xff1a;“可也。未若贫而乐&#xff0c;富而好礼者也。” 子贡曰&#xff1a;“《诗》云&#xff1a;‘如切如磋&#xff0c;如琢如磨。’其斯之谓与&#xff1f;”子曰&#xff1a;“…

mybatis plus新版代码生成器,类型转换处理器ITypeConvertHandler使用

目录 引言关键代码源码分析记录一坑类型转换的第二种方式完整源码地址 引言 当默认生成的数据类型不满足时&#xff0c;就需要自定义指定要生成的类型 关键代码 FastAutoGenerator.create(url, username, password).dataSourceConfig(builder -> {builder.typeConvertHandl…

Python计算加速利器

迷途小书童的 Note 读完需要 6分钟 速读仅需 2 分钟 1 简介 Python 是一门应用非常广泛的高级语言&#xff0c;但是&#xff0c;长久以来&#xff0c;Python的运行速度一直被人诟病&#xff0c;相比 c/c、java、c#、javascript 等一众高级编程语言&#xff0c;完全没有优势。 那…

记一次因函数入参没有带类型所引发的问题

工作中&#xff0c;sit测试中&#xff0c;测试突然发现页面异常。经排查&#xff0c;是函数参数没有定义类型所以&#xff0c;dart默认是dynamic类型&#xff0c;而dynamic编译阶段不检查类型&#xff0c;正是由于编译阶段不检查类型&#xff0c;很明显的错误也只能运行的时候才…

【Axure高保真原型】中继器网格图片拖动摆放

今天和大家分享中继器网格图片拖动摆放的原型模板&#xff0c;我们可以通过鼠标拖动来移动图片&#xff0c;拖动过程其他图标会根据图片拖动自动排列&#xff0c;松开鼠标是图片停放在指定位置&#xff0c;其他图标自动排列。那这个模板是用中继器制作的&#xff0c;所以使用也…

C# 跨线程访问窗体控件

在不加任何修饰的情况下&#xff0c;C# 默认不允许跨线程访问控件&#xff0c;实际在项目开发过程中&#xff0c;经常使用跨线程操作控件属性&#xff0c;需要设置相关属性才能正确使用&#xff0c;两种方法设置如下&#xff1a; 方法1&#xff1a;告诉编译器取消跨线程访问检…

XML—标记语言

什么是XML&#xff1f; Extensible Markup Language&#xff0c;可扩展标记语言。 那标记语言是什么&#xff1f; 用文字做标记表达一些效果或携带一些数据。比如&#xff1a;HTML、XML 我的理解&#xff1a;用倾盆大雨表达雨很大 那XML为什么说是可扩展的呢&#xff1f; 还…

ethers.js9、过滤事件

在 合约监听 的基础上,我们拓展一下,在监听的过程中增加过滤器,监听指定地址的转入转出。 过滤器 当合约创建日志(释放事件)时,它最多可以包含[4]条数据作为索引(indexed)。索引数据经过哈希处理并包含在布隆过滤器中,这是一种允许有效过滤的数据结构。因此,一个事件…

Java学数据结构(4)——散列表Hash table 散列函数 哈希冲突

目录 引出散列表Hash table关键字Key和散列函数(hash function)散列函数解决collision哈希冲突&#xff08;碰撞&#xff09;分离链接法(separate chaining)探测散列表(probing hash table)双散列(double hashing) Java标准库中的散列表总结 引出 1.散列表&#xff0c;key&…

SQLite数据库C_C++接口(保姆级API应用 1.4W字)(全网最详细介绍,学完必掌握)

目录 sqlite3的C/C API应用 前言 SQLite3库安装 API函数 打开、关闭、错误处理 打开 返回值 关闭 错误调试 实际应用 执行SQL&#xff08;DDL、DML&#xff09; API介绍 实际应用 回调函数查询 API介绍 实际应用 全缓冲查询 API介绍 实际应用 字节缓冲查询…

【Linux】【驱动】自动创建设备节点

【Linux】【驱动】自动创建设备节点 续驱动代码操作指令linux端从机端 续 这里展示了如何自动的方式去创建一个字符类的节点 下面就是需要调用到的程序 函数 void cdev_init(struct cdev *, const struct file_operations *);第一个参数 要初始化的 cdev 第二个参数 文件操作…

【微服务部署】01-Kubernetes部署流程

文章目录 部署1. Kubernetes是什么2. Kubernetes的优势3. 环境搭建4. 应用部署 部署 1. Kubernetes是什么 Kubernetes是一个用于自动部署、扩展和管理容器化应用程序的开源系统 2. Kubernetes的优势 自动化容器部署资源管理与容器调度服务注册发现与负载均衡内置配置与秘钥…