【考研408计算机组成原理】数值表示和运算之快速数值转换

2024-06-21 21:28

本文主要是介绍【考研408计算机组成原理】数值表示和运算之快速数值转换,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

                                                                            苏泽 

“弃工从研”的路上很孤独,于是我记下了些许笔记相伴,希望能够帮助到大家

另外,利用了工作之余的一点点时间,整理了一套考研408的知识图谱,

我根据这一套知识图谱打造了这样一个408知识图谱问答系统

里面的每一个回答都是根据考研408的考点回复的

 

目前暂时只接入了微信,如果大家对这个问答系统感兴趣的话可以在我的主页里找到我的微信号

找我拉进测试群免费体验哦


这一章希望分享一份快速数值转换的技巧笔记

目录

这一章希望分享一份快速数值转换的技巧笔记

数值转换的几个方向

进制转换

这里我们可以观察这个表发现一个规律,那就是所有十六进制的每一位都能够用 二进制的四位来表示

各种“码”的转换

关于原码、反码、补码以及移码的转换,以下是整理的要点:

其中原码转补码的小技巧

考研易错点难点:浮点数

先说浮点数的定义

☆求补运算的使用


数值转换的几个方向

进制转换

首先考研只会考到2进制 10进制 和16进制的转换 所以对于这些数值之间的表示和不同进制之间的转换就成为了一项必备技能

而这些进制的转换相信大家都不陌生 通过辗转相除法之类的计算方法就能计算得出, 但我这里要记录的  是一种能够通过少量记忆 达到免除计算 节省时间的一种方法

首先我们可以看到这样一个表  这个表并不稀奇 大家也能自己去算一下 也不需要背考试的时候

其实只需要把16进制当中的A~F对应的十进制数给写到草稿纸上即可

A~F分别对应的是10~15

这里我们可以观察这个表发现一个规律,那就是所有十六进制的每一位都能够用 二进制的四位来表示

用下面这个例子快速掌握这个小技巧

这里要求16进制转2进制

那么现在问题就变成了“3”如何用4位二进制表示,是不是2的1次方+2的0次方,所以是0011

B是11 =8+0+2+1  所以是1011

...以此类推

这样我们把每一位转成二进制的数 都写到纸上  然后按顺序拼起来就是结果了 

就不需要用传统方法模16那种方法 无需计算快速得出结果

各种“码”的转换

再到经典的原、反、补、移码了

先看这张整理好的图

关于原码、反码、补码以及移码的转换,以下是整理的要点:

  1. 原码

    • 原码是最直接的表示方式,最高位是符号位,0代表正数,1代表负数。其余位表示数值的大小。
  2. 反码

    • 正数的反码与其原码相同。
    • 负数的反码是将其原码除符号位外的所有位取反。
  3. 补码

    • 正数的补码与其原码相同。
    • 负数的补码是其反码加1。
  4. 移码

    • 移码是补码的一种变体,其符号位取反。这使得正数的移码比补码大1,而负数的移码比补码小1。

其中原码转补码的小技巧

这里有个小技巧 王道里面也说过的:符号位不变,从左往右数第一个“1” ,它的左边全取反 右边保留原样

这个技巧能够其他转换当中的完美等价“数值位取反加1”这一条件 

考研易错点难点:浮点数

先说浮点数的定义

之所以“浮”  是因为他的小数点 飘忽不定  例如1.01 可以写成10.1*10^-1

所以计算机当中需要一个统一的标准  将这些小数给统一起来 就有了下面的部分 来介绍计算机是如何统一的表示浮点数的

  1. 浮点数的组成

    • 浮点数通常由三部分组成:阶码(Exponent)、尾数(Mantissa)和符号位(Sign)。

关于浮点数移位的解释 和记忆的口诀

逻辑移位: 将操作数视为⽆符号 ,⼀律补0

  循环移位:

☆求补运算的使用

16进制->补码 (快速)

原码

正数补码=原码,所以不多说

负数2进制补码: ⽤常归⽅法即可

负数16进制补码: 求补运算,说⽩了就是求这个数的⼀个互补值,使得这个数最高位能够进1位且其他位都为 0,这种运算就称之为求补运算 

 求带符 号补 FCA358H 真值

使用求补运算相当求让FCA358H加上一个数使其=10000000H

 FCA358H+035CA8H= 10000000H

此时我们求出来的是FCA358H的补数,由于FCA358H显然是负数, 所以在转为真值的时候  定要记得加上负号 

同时,将有符号补数转为原码时也要保持符号一致性,所以最后FCA358H原码为: 835CA8H

16 进制原码快速 ->补码
相当于让 1000H 减去该数本⾝
例如  例:求-002BH的补码

1000H-002BH =FFD5H

这篇关于【考研408计算机组成原理】数值表示和运算之快速数值转换的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1082375

相关文章

LangChain转换链:让数据处理更精准

1. 转换链的概念 在开发AI Agent(智能体)时,我们经常需要对输入数据进行预处理,这样可以更好地利用LLM。LangChain提供了一个强大的工具——转换链(TransformChain),它可以帮我们轻松实现这一任务。 转换链(TransformChain)主要是将 给定的数据 按照某个函数进行转换,再将 转换后的结果 输出给LLM。 所以转换链的核心是:根据业务逻辑编写合适的转换函

乐鑫 Matter 技术体验日|快速落地 Matter 产品,引领智能家居生态新发展

随着 Matter 协议的推广和普及,智能家居行业正迎来新的发展机遇,众多厂商纷纷投身于 Matter 产品的研发与验证。然而,开发者普遍面临技术门槛高、认证流程繁琐、生产管理复杂等诸多挑战。  乐鑫信息科技 (688018.SH) 凭借深厚的研发实力与行业洞察力,推出了全面的 Matter 解决方案,包含基于乐鑫 SoC 的 Matter 硬件平台、基于开源 ESP-Matter SDK 的一

《计算机英语》Unit 1 Computer Overview 计算机概述

期末试卷组成 1、选择20道 2、判断20道 3、词汇翻译(单词+词组,参照课后习题) 4、翻译2道(一道原题,参照作业) SectionA About Computer 关于计算机 algorithm          n.  算法  operate          v.  操作  digital           adj. 数字的  integrated circuit

LVGL快速入门笔记

目录 一、基础知识 1. 基础对象(lv_obj) 2. 基础对象的大小(size) 3. 基础对象的位置(position) 3.1 直接设置方式 3.2 参照父对象对齐 3.3 获取位置 4. 基础对象的盒子模型(border-box) 5. 基础对象的样式(styles) 5.1 样式的状态和部分 5.1.1 对象可以处于以下状态States的组合: 5.1.2 对象

数据库原理与安全复习笔记(未完待续)

1 概念 产生与发展:人工管理阶段 → \to → 文件系统阶段 → \to → 数据库系统阶段。 数据库系统特点:数据的管理者(DBMS);数据结构化;数据共享性高,冗余度低,易于扩充;数据独立性高。DBMS 对数据的控制功能:数据的安全性保护;数据的完整性检查;并发控制;数据库恢复。 数据库技术研究领域:数据库管理系统软件的研发;数据库设计;数据库理论。数据模型要素 数据结构:描述数据库

工程文档CAD转换必备!在 Java 中将 DWG 转换为 JPG

Aspose.CAD 是一个独立的类库,以加强Java应用程序处理和渲染CAD图纸,而不需要AutoCAD或任何其他渲染工作流程。该CAD类库允许将DWG, DWT, DWF, DWFX, IFC, PLT, DGN, OBJ, STL, IGES, CFF2文件、布局和图层高质量地转换为PDF和光栅图像格式。 Aspose API支持流行文件格式处理,并允许将各类文档导出或转换为固定布局文件格

计算机组成原理——RECORD

第一章 概论 1.固件  将部分操作系统固化——即把软件永恒存于只读存储器中。 2.多级层次结构的计算机系统 3.冯*诺依曼计算机的特点 4.现代计算机的组成:CPU、I/O设备、主存储器(MM) 5.细化的计算机组成框图 6.指令操作的三个阶段:取指、分析、执行 第二章 计算机的发展 1.第一台由电子管组成的电子数字积分和计算机(ENIAC) 第三章 系统总线

GaussDB关键技术原理:高性能(二)

GaussDB关键技术原理:高性能(一)从数据库性能优化系统概述对GaussDB的高性能技术进行了解读,本篇将从查询处理综述方面继续分享GaussDB的高性能技术的精彩内容。 2 查询处理综述 内容概要:本章节介绍查询端到端处理的执行流程,首先让读者对查询在数据库内部如何执行有一个初步的认识,充分理解查询处理各阶段主要瓶颈点以及对应的解决方案,本章以GaussDB为例讲解查询执行的几个主要阶段

计算机Java项目|基于SpringBoot的网上摄影工作室

作者主页:编程指南针 作者简介:Java领域优质创作者、CSDN博客专家 、CSDN内容合伙人、掘金特邀作者、阿里云博客专家、51CTO特邀作者、多年架构师设计经验、腾讯课堂常驻讲师 主要内容:Java项目、Python项目、前端项目、人工智能与大数据、简历模板、学习资料、面试题库、技术互助 收藏点赞不迷路  关注作者有好处 文末获取源码  项目编号:L-BS-QBBSSPRINGBOOT

直接得到Json串,转换为字典

0.新创建一个json文件,把json串拷贝到里面 1.先通过MainBundle找到资源对应的路径 2.将文件转换为NSData 3.通过NSJSonSerization得到字典 NSString*fileName=[[NSBundle mainBundle] pathForResource:@"myJson" ofType:@"json"];           NS