【考研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

相关文章

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语

MySQL中的表连接原理分析

《MySQL中的表连接原理分析》:本文主要介绍MySQL中的表连接原理分析,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、背景2、环境3、表连接原理【1】驱动表和被驱动表【2】内连接【3】外连接【4编程】嵌套循环连接【5】join buffer4、总结1、背景

深度解析Spring AOP @Aspect 原理、实战与最佳实践教程

《深度解析SpringAOP@Aspect原理、实战与最佳实践教程》文章系统讲解了SpringAOP核心概念、实现方式及原理,涵盖横切关注点分离、代理机制(JDK/CGLIB)、切入点类型、性能... 目录1. @ASPect 核心概念1.1 AOP 编程范式1.2 @Aspect 关键特性2. 完整代码实

Java Stream的distinct去重原理分析

《JavaStream的distinct去重原理分析》Javastream中的distinct方法用于去除流中的重复元素,它返回一个包含过滤后唯一元素的新流,该方法会根据元素的hashcode和eq... 目录一、distinct 的基础用法与核心特性二、distinct 的底层实现原理1. 顺序流中的去重

Linux如何快速检查服务器的硬件配置和性能指标

《Linux如何快速检查服务器的硬件配置和性能指标》在运维和开发工作中,我们经常需要快速检查Linux服务器的硬件配置和性能指标,本文将以CentOS为例,介绍如何通过命令行快速获取这些关键信息,... 目录引言一、查询CPU核心数编程(几C?)1. 使用 nproc(最简单)2. 使用 lscpu(详细信

利用Python脚本实现批量将图片转换为WebP格式

《利用Python脚本实现批量将图片转换为WebP格式》Python语言的简洁语法和库支持使其成为图像处理的理想选择,本文将介绍如何利用Python实现批量将图片转换为WebP格式的脚本,WebP作为... 目录简介1. python在图像处理中的应用2. WebP格式的原理和优势2.1 WebP格式与传统

Spring @Scheduled注解及工作原理

《Spring@Scheduled注解及工作原理》Spring的@Scheduled注解用于标记定时任务,无需额外库,需配置@EnableScheduling,设置fixedRate、fixedDe... 目录1.@Scheduled注解定义2.配置 @Scheduled2.1 开启定时任务支持2.2 创建

Spring Boot 实现 IP 限流的原理、实践与利弊解析

《SpringBoot实现IP限流的原理、实践与利弊解析》在SpringBoot中实现IP限流是一种简单而有效的方式来保障系统的稳定性和可用性,本文给大家介绍SpringBoot实现IP限... 目录一、引言二、IP 限流原理2.1 令牌桶算法2.2 漏桶算法三、使用场景3.1 防止恶意攻击3.2 控制资源

一文详解如何在idea中快速搭建一个Spring Boot项目

《一文详解如何在idea中快速搭建一个SpringBoot项目》IntelliJIDEA作为Java开发者的‌首选IDE‌,深度集成SpringBoot支持,可一键生成项目骨架、智能配置依赖,这篇文... 目录前言1、创建项目名称2、勾选需要的依赖3、在setting中检查maven4、编写数据源5、开启热