计算机基础知识之浮点数的表示

news/2025/1/18 7:00:19/文章来源:https://www.cnblogs.com/kohler21/p/18240395

目录
  • 定点数表示
  • 浮点数表示
    • 习题
  • 浮点数的规格化
    • 例题
    • 习题

计算机基础知识之原码、补码、反码和移码:https://www.cnblogs.com/kohler21/p/18233912

定点数表示

定点小数(纯小数)在计算机中的表示形式:

注:在计算机中,定点小数主要用于表示浮点数的尾数,并没有高级语言数据类型与之相对应。

定点整数在计算机中的表示形式:

注:在C语言中,char、short、int、long型都属于定点整数。

定点数所能表示的数据范围与下列因素有关。

  • 机器字长:字长越长,其表示的数据范围就越大。
  • 所采用的机器码:补码和移码所能表示的数据范围,比原码和反码所能表示的数据范围要多一个最小负数。

实际上,计算机中处理的数不一定都是纯小数或纯整数(例如圆周率3.1415926)。因此,这样的数不能直接用定点小数或定点整数表示。

希望将浮点数直接表示在寄存器中:小数点的位置由寄存器中指定数位的内容给出;正负号由寄存器中指定数位的内容给出。

二进制浮点数可采用类似十进制科学记数法的表示方法。

十进制浮点数的表示:

进而推广到二进制:

浮点数表示

进而得出浮点数在机器中的表示形式:

  • 阶码的位数决定了数据表示的范围,位数越多,能表示的数据范围就越大。
  • 阶码的值决定了小数点的位置
  • 尾数的位数决定了数据的表示精度。阶码长度相同时,分配给尾数的位数越多,数据表示的精度就越高。
  • 阶码可采用原码、补码、反码、移码进行表示。
  • 尾数可采用原码、补码、反码进行表示。
  • 对应的浮点数表示范围会略有不同。

浮点数在机器中额度表示形式:N = \(r^{E}\) X M(r可取2、4、8、16等)。

【练习】
(1)设浮点数字长为8位,其中阶码3位(含1位阶符),尾数5位(含1位数符),阶码和尾数均以原码表示,基数r为8,则浮点数的最大最小值分别是多少?
(2)设定点数原码为8位,则定点数的最大最小值分别是多少?(3)比较(1)和(2)能得出什么结论?

由此看见浮点数有效地扩大了数据的表示范围。

尽管浮点数有效扩大了数据表示范围,但受机器字长限制,浮点数仍然存在溢出现象

  • 当浮点数的阶码大于最大阶码时,称为上溢,此时机器停止运算,浮点运算器件会显示溢出标志。
  • 当浮点数的阶码小于最小阶码时,称为下溢,虽然此时数据不能被精确表示,但由于发生下溢时数据的绝对值很小,通常将尾数各位强置为0,按机器0处理,此时机器可以继续运行。
  • 当一个浮点数在正、负数区域中但并不在某个数轴刻度上时,也会出现精度溢出的问题,此时只能用近似数表示。

习题

【习题1】在浮点数的机器码(即机器数)表示中,不在机器码中出现(即隐含)的是(A)。

A.基数r

B.阶码E

C.尾数M

D.符号f

【习题2】假设浮点数A和B的字长相同, A的阶码位数大于B的阶码位数, A的尾数位数小于B的位数位数,其他规定都相同,则A和B可表示的数的范围和精度是(C )。
A. B可表示的数的范围大且精度高
B. A和B可表示的数的范围和精度相同
C. A可表示的数的范围大但精度低
D. A可表示的数的范围大且精度高

解析:阶码位数越大表示的数的范围越大,尾数位数越大则表示的数的精度越高。

【习题3】某浮点数字长为12位,其中阶码4位(含1位阶符号),基数为2,尾数8位(含1位数符),若阶码和
尾数都用补码表示,则该浮点数所能表示的最大正数是(D)。
A. \(2^{8}\)
B. \(2^{8}\) - 1
C. \(2^{7}\)
D.\(2^{7}\)-1

解析: 参考上方数轴中的最大正数的表示。

浮点数的规格化

根据浮点数的表示这一小节会发现存在一个问题:同一浮点数可能存在多种表示形式,也就是会有不同的阶码和尾数的组合。

举例如下:

浮点数的规格化通常要求浮点数在数据表示时对尾数进行规格化处理,即使得尾数的最高数值位必须是一个有效值(尾数的数值部分的最高位为1)。在上述例子中只有第一种是符合规格化要求的。

浮点数规格化带来以下好处:

  • 使浮点数的表示形式唯一
  • 使浮点数的表示精度最高。若数值部分的最高为0,则实际上该位对数值的表达是没有作用的。因为在构成数值时,该位的位权是没有作用的。而规格化就是要移除尾数数值部分最高位的0,这相当于数值部分能够补充相应数量的低位进而提高了表示精度。

对于非规格化尾数,需要对其进行规格化操作,即根据具体形式通过将非规格化尾数的数值部分进行左移或右移,并相应减少或增加阶码值的操作进行规格化,对应的规格化方法分别称为向左规格化(简称左规)和向右规格化(简称右规)。
对于基数r不同的浮点数,因其规格化数的形式不同,规格化过程也不同。

  • 当r=2时,尾数数值部分最高位为1的数为规格化数。

    • 左规:尾数数值部分每左移1位,阶码减1。

    • 右规:尾数数值部分每右移1位,阶码加1。

  • 当r=4时,尾数数值部分最高2位不全为0的数为规格化数。

    • 左规:尾数数值部分每左移2位,阶码减1。

    • 右规:尾数数值部分每右移2位,阶码加1。

    ​ 类比同上。

  • 当r=8时,尾数数值部分最高3位不全为0的数为规格化数。

    • 左规:尾数数值部分每左移3位,阶码减1。
    • 右规:尾数数值部分每右移3位,阶码加1

依此类推,不难得到基数r为16或\(2^{n}\)时的规格化过程。

基数r不同,对数的表示范围和精度等都有影响。一般来说:基数r越大,可表示的浮点数范围越大,而且所表示的数的个数越多。但浮点数的精度反而下降。

浮点数规格化后的表示范围:

例题

【例题1】设浮点数字长为16位,其中阶码5位(含1位阶符),尾数11位(含1位数符),将十进制数-56写成二进制定点数和浮点数(要求规格化表示),并分别写出它们各自的机器数(原码、反码、补码)形式。

【例题2】设浮点数字长为16位,其中阶码5位(含1位阶符),尾数11位(含1位数符),将十进制数+\(\frac {13}{128}\)写成二进制定点数和浮点数(要求规格化表示),并写出它们各自的机器数(原码、反码、补码)形式。

【例题3】设浮点数字长为16位,其中阶码5位(含1位阶符),尾数11位(含1位数符),写出十进制数-\(\frac {53}{512}\)对应的浮点规格化数的原码、反码和补码以及阶码用移码、尾数用补码的形式。

习题

【习题1】浮点数规格化带来的主要好处是( D)
A.方便浮点运算
B. 防止运算时数据溢出
C.增加数据的表示范围
D.增加数据的表示精度

解析:浮点数规格化带来以下好处:

  • 使浮点数的表示形式唯一
  • 使浮点数的表示精度最高

【习题2】假设浮点数A和B的字长、格式都相同,A的基数大于B,其他规定都相同,则A和B可表示的数的范围和精度是(C)。
A. B可表示的数的范围大且精度高

B. A和B可表示的数的范围和精度相同

C. A可表示的数的范围大但精度低

D. A可表示的数的范围大且精度高

解析:基数r不同,对数的表示范围和精度等都有影响。一般来说:基数r越大,可表示的浮点数范围越大,而且所表示的数的个数越多。但浮点数的精度反而下降。

【习题3】若某浮点数为\(2^{11}\)×1.1011,其中阶码为原码表示,尾数为补码表示,则该浮点数(C)。
A.需要将尾数数值部分右移1位规格化
B.需要将尾数数值部分右移2位规格化

C.需要将尾数数值部分左移1位规格化
D.已经规格化

【习题4】假设浮点数的基数为8,尾数用原码表示,则以下尾数为规格化数的是(B)
A. 1. 0001001
B. 1. 0010111

C. 0. 0001001
D. 0. 0000111

解析:当r=8时,尾数数值部分最高3位不全为0的数为规格化数。

推荐阅读:

  • 计算机基础知识之原码、补码、反码和移码

欢迎关注公众号:愚生浅末
image

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

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

相关文章

WCP知识协作平台V5.1.7版更新(智能助手)

WCP知识协作平台V5.1.7版更新智能助手集成:侧边栏智能助手的加入,利用先进的人工智能技术,提供了涵盖名词解释、翻译、答案生成、知识摘要、知识问答以及知识图谱生成的多功能服务。这一集成不仅丰富了用户的交互体验,还显著增强了知识获取与处理的能力。 名词解释:在阅读…

【PB案例学习笔记】-04文件浏览器

写在前面 这是PB案例学习笔记系列文章的第4篇,该系列文章适合具有一定PB基础的读者。 通过一个个由浅入深的编程实战案例学习,提高编程技巧,以保证小伙伴们能应付公司的各种开发需求。 文章中设计到的源码,小凡都上传到了gitee代码仓库https://gitee.com/xiezhr/pb-project…

PingCastle 3.2.0.1 - Active Directory 安全检测和评估

PingCastle 3.2.0.1 - Active Directory 安全检测和评估PingCastle 3.2.0.1 - Active Directory 安全检测和评估 活动目录域安全分析工具 请访问原文链接:https://sysin.org/blog/pingcastle/,查看最新版。原创作品,转载请保留出处。 作者主页:sysin.org在 20% 的时间内获得…

SQL Server Management Studio (SSMS) 20.1 - 微软数据库管理工具

SQL Server Management Studio (SSMS) 20.1 - 微软数据库管理工具SQL Server Management Studio (SSMS) 20.1 - 微软数据库管理工具 请访问原文链接:https://sysin.org/blog/ssms/,查看最新版。原创作品,转载请保留出处。 作者主页:sysin.org笔者注:SQL Server 2014 及之前…

SQL Server 2022 RTM 最新累积更新:Cumulative Update #13 for SQL Server 2022 RTM

SQL Server 2022 RTM (最新累积更新) - Cumulative Update #13 for SQL Server 2022 RTMSQL Server 2022 RTM (最新累积更新) - 基于 Azure 的持续性能和安全创新 Cumulative Update #13 for SQL Server 2022 RTM 请访问原文链接:https://sysin.org/blog/sql-server-2022/,查…

Kali Linux 2024.2 发布 (t64, GNOME 46 Community Packages) - 领先的渗透测试发行版

Kali Linux 2024.2 发布 (t64, GNOME 46 & Community Packages) - 领先的渗透测试发行版Kali Linux 2024.2 发布 (t64, GNOME 46 & Community Packages) - 领先的渗透测试发行版 The most advanced Penetration Testing Distribution 请访问原文链接:https://sysin.or…

运筹学练习Python精解——网络计划技术

练习1 某新产品研制项目的各项工序、所需时间及相互关系如下表所示,试画出该项目的网络图,分别用和双代号、单代号方法以及表上计算法计算事项时间参数,并求出关键路线。工序 工序代号 所需时间 紧后工序产品及工艺设计 A 60 B, C, D, E外购配套件 B 45 K下料、锻件 C 10 F工…

树状数组

树状数组(Binary Indexed Tree,BIT)是一种用于维护 \(n\) 个元素的前缀信息的数据结构。 以前缀和为例,对于数列 \(a\),可以将其存储为前缀和数组 \(s\) 的形式,其中 \(s_i = \sum \limits_{j=1}^i a_j\)。那么通过前缀和数组,就可以快速求出原数组中给定区间中数字的和…

树上前缀和与差分

树上前缀和 设 \(sum_i\) 表示根节点到节点 \(i\) 的权值总和。 则有:对于点权,\(x,y\) 路径上的和为 \(sum_x + sum_y - sum_{lca} - sum_{fa_{lca}}\)。 对于边权,\(x,y\) 路径上的和为 \(sum_x + sum_y - 2 \times sum_{lca}\)。习题:P4427 [BJOI2018] 求和解题思路 预处…

SynProject 介绍---(synopse理解的版本控制和文档自动化生成)

SynProject 介绍---(synopse理解的版本控制和文档自动化生成) Synopse SynProject是一个用于Delphi项目的源代码版本控制和自动化文档生成的开源应用程序。它在GPL许可下发布。 有关其全部功能的完整列表,请参阅SynProject功能。源代码可从本源代码存储库获取。请选择上方的…

品牌全域人群资产增长飞轮

品牌人群资产是指品牌通过一系列营销活动和用户互动所积累的、对品牌有一定认知、情感和忠诚度的用户群体。这些资产是品牌的无形资产,对于品牌的长期成功和市场份额的扩张至关重要。 品牌人群资产可以模拟成一个多层次、多维度的球形结构体,其中核心用户群位于中心,随着用户…

TCP传输控制协议

网络编程 TCP传输控制协议 传输层中最为常见的两个协议分别是传输控制协议TCP(Transmission Control Protocol)和用户数据报协议UDP(User Datagram Protocol) 一、TCP协议的特点:TCP是面向连接的,端对端(一对一)的可靠的协议,可修复损坏数据,全双工的连接。 1.TCP协议判…