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

相关文章

Linux使用dd命令来复制和转换数据的操作方法

《Linux使用dd命令来复制和转换数据的操作方法》Linux中的dd命令是一个功能强大的数据复制和转换实用程序,它以较低级别运行,通常用于创建可启动的USB驱动器、克隆磁盘和生成随机数据等任务,本文... 目录简介功能和能力语法常用选项示例用法基础用法创建可启动www.chinasem.cn的 USB 驱动

Redis主从/哨兵机制原理分析

《Redis主从/哨兵机制原理分析》本文介绍了Redis的主从复制和哨兵机制,主从复制实现了数据的热备份和负载均衡,而哨兵机制可以监控Redis集群,实现自动故障转移,哨兵机制通过监控、下线、选举和故... 目录一、主从复制1.1 什么是主从复制1.2 主从复制的作用1.3 主从复制原理1.3.1 全量复制

Redis主从复制的原理分析

《Redis主从复制的原理分析》Redis主从复制通过将数据镜像到多个从节点,实现高可用性和扩展性,主从复制包括初次全量同步和增量同步两个阶段,为优化复制性能,可以采用AOF持久化、调整复制超时时间、... 目录Redis主从复制的原理主从复制概述配置主从复制数据同步过程复制一致性与延迟故障转移机制监控与维

Python 标准库time时间的访问和转换问题小结

《Python标准库time时间的访问和转换问题小结》time模块为Python提供了处理时间和日期的多种功能,适用于多种与时间相关的场景,包括获取当前时间、格式化时间、暂停程序执行、计算程序运行时... 目录模块介绍使用场景主要类主要函数 - time()- sleep()- localtime()- g

shell脚本快速检查192.168.1网段ip是否在用的方法

《shell脚本快速检查192.168.1网段ip是否在用的方法》该Shell脚本通过并发ping命令检查192.168.1网段中哪些IP地址正在使用,脚本定义了网络段、超时时间和并行扫描数量,并使用... 目录脚本:检查 192.168.1 网段 IP 是否在用脚本说明使用方法示例输出优化建议总结检查 1

SpringCloud配置动态更新原理解析

《SpringCloud配置动态更新原理解析》在微服务架构的浩瀚星海中,服务配置的动态更新如同魔法一般,能够让应用在不重启的情况下,实时响应配置的变更,SpringCloud作为微服务架构中的佼佼者,... 目录一、SpringBoot、Cloud配置的读取二、SpringCloud配置动态刷新三、更新@R

JAVA中整型数组、字符串数组、整型数和字符串 的创建与转换的方法

《JAVA中整型数组、字符串数组、整型数和字符串的创建与转换的方法》本文介绍了Java中字符串、字符数组和整型数组的创建方法,以及它们之间的转换方法,还详细讲解了字符串中的一些常用方法,如index... 目录一、字符串、字符数组和整型数组的创建1、字符串的创建方法1.1 通过引用字符数组来创建字符串1.2

Redis主从复制实现原理分析

《Redis主从复制实现原理分析》Redis主从复制通过Sync和CommandPropagate阶段实现数据同步,2.8版本后引入Psync指令,根据复制偏移量进行全量或部分同步,优化了数据传输效率... 目录Redis主DodMIK从复制实现原理实现原理Psync: 2.8版本后总结Redis主从复制实

Rust中的Option枚举快速入门教程

《Rust中的Option枚举快速入门教程》Rust中的Option枚举用于表示可能不存在的值,提供了多种方法来处理这些值,避免了空指针异常,文章介绍了Option的定义、常见方法、使用场景以及注意事... 目录引言Option介绍Option的常见方法Option使用场景场景一:函数返回可能不存在的值场景

如何测试计算机的内存是否存在问题? 判断电脑内存故障的多种方法

《如何测试计算机的内存是否存在问题?判断电脑内存故障的多种方法》内存是电脑中非常重要的组件之一,如果内存出现故障,可能会导致电脑出现各种问题,如蓝屏、死机、程序崩溃等,如何判断内存是否出现故障呢?下... 如果你的电脑是崩溃、冻结还是不稳定,那么它的内存可能有问题。要进行检查,你可以使用Windows 11