浮点型的位结构和表示的值

位结构

在这里插入图片描述

float 各部分的含义

  • 符号位:
    • 为 0 表示正数,为 1 表示负数。
  • 指数部分:
    • 指数部分是一个移码。
    • 指数部分有 8 位,首先当成无符号整型,则值域是 [0, 255] .
    • 因为是移码,所以 移码值 = 无符号整型值 - 127 则移码值的值域为 [-127, 128] .
    • 但是浮点的指数部分不是标准的移码,没有 -127 这个值。当指数部分全 0 时,标准移码的值是 -127, 但是浮点中把它当成 -126, 表示非规格化数。
    • 在规格化数中,指数部分的无符号整型值减去 127 就是实际的指数值。
    • 在非规格化数中,指数位全为 0,指数值为 -126,不再是指数部分的无符号整型值减去 127.
    • 此外,当指数部分的所有位都为 1 时,不再是表示具体的小数值,而是表示 无穷NaN 这种抽象的值。指数部分全 1 时,标准的移码值是 128, 但是浮点中表示抽象值。所以浮点的指数部分在表示具体的小数时的指数值的值域为 [-126, 127].
  • 尾数部分:
    • 尾数部分有 23 位,是一个无符号整型。

double 各部分的含义

  • 符号位:
    • 为 0 表示正数,为 1 表示负数。
  • 指数部分:
    • 指数部分是一个移码。
    • 指数部分有 11 位,首先当成无符号整型,则值域是 [0, 2047] .
    • 因为是移码,所以 移码值 = 无符号整型值 - 1023 则移码值的值域为 [-1023, 1024] .
    • 但是浮点的指数部分不是标准的移码,没有 -1023 这个值。当指数部分全 0 时,标准移码的值是 -1023, 但是浮点中把它当成 -1022, 表示非规格化数。
    • 在规格化数中,指数部分的无符号整型值减去 1023 就是实际的指数值。
    • 在非规格化数中,指数位全为 0,指数值为 -1022,不再是指数部分的无符号整型值减去 1023.
    • 此外,当指数部分的所有位都为 1 时,不再是表示具体的小数值,而是表示 无穷NaN 这种抽象的值。指数部分全 1 时,标准的移码值是 1024, 但是浮点中表示抽象值。所以浮点的指数部分在表示具体的小数时的指数值的值域为 [-1022, 1023].
  • 尾数部分:
    • 尾数部分有 52 位,是一个无符号整型。

值计算公式

float 的值计算公式

规格化数的值:
value=(−1)sign×2exponent−127×(1+mantissa223) \text{value} = (-1)^{\text{sign}} \times 2^{\text{exponent} - 127} \times \left(1 + \frac{\text{mantissa}}{2^{23}}\right) value=(1)sign×2exponent127×(1+223mantissa)

非规格化数的值:
value=(−1)sign×2−126×(mantissa223) \text{value} = (-1)^{\text{sign}} \times 2^{-126} \times \left(\frac{\text{mantissa}}{2^{23}}\right) value=(1)sign×2126×(223mantissa)

在这里插入图片描述
在这里插入图片描述

double 的值计算公式

规格化数的值:
value=(−1)sign×2exponent−1023×(1+mantissa252) \text{value} = (-1)^{\text{sign}} \times 2^{\text{exponent} - 1023} \times \left(1 + \frac{\text{mantissa}}{2^{52}}\right) value=(1)sign×2exponent1023×(1+252mantissa)

非规格化数的值:
value=(−1)sign×2−1022×(mantissa252) \text{value} = (-1)^{\text{sign}} \times 2^{-1022} \times \left(\frac{\text{mantissa}}{2^{52}}\right) value=(1)sign×21022×(252mantissa)

在这里插入图片描述

浮点特殊值

NaN

  • 指数部分所有位都为 1.
  • 尾数部分不为 0.

正无穷、负无穷

  • 指数部分所有位都为 1.
  • 尾数部分所有位都为 0.

则根据符号位来确定是正无穷还是负无穷。符号位为 0 则是正无穷,符号位为 1 则是负无穷。

总结

只要指数部分所有位都为 1, 这个浮点数就不再是具体的小数值,而是 NaN, 无穷 这种抽象的概念。

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

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

相关文章

39_基于深度学习的行人摔倒检测识别系统(yolo11、yolov8、yolov5+UI界面+Python项目源码+模型+标注好的数据集)

目录 项目介绍🎯 功能展示🌟 一、环境安装🎆 环境配置说明📘 安装指南说明🎥 环境安装教学视频 🌟 二、数据集介绍🌟 三、系统环境(框架/依赖库)说明🧱 系统环…

【系统分析师】高分论文:论企业数据治理

【摘要】 2022年3月,我作为系统分析师及IT 负责人,参加了我司的企业级数据平台建设项目,该项目作为我司在企业数字化转型过程中重要的里程碑,在我司数字化运营中扮演着关键的角色。该项目主要包含企业级数据仓库,数据治…

Seata原理分析

简介Apache Seata™ (incubating) 是什么?Seata 是一款开源的分布式事务解决方案,致力于在微服务架构下提供高性能和简单易用的分布式事务服务。在 Seata 开源之前,其内部版本在阿里系内部一直扮演着应用架构层数据一致性的中间件角色&#x…

力扣 30 天 JavaScript 挑战 第38天 (第九题)学习了 语句表达式的区别 高级函数 promise async await 节流

开始答题 版本一: /*** param {Function} fn* return {Function}*/ var once function(fn) {let runCount0return function(...args){runCountrunCount 1 ? return fn(...args) :return undefined} };/*** let fn (a,b,c) > (a b c)* let onceFn once(fn)…

25年八月份宁德时代社招部分岗位入职Verify测评演绎数字推理SHL题型变更、题库使用说明

开始测评前,请注意:1、挑选一个安静的环境,选择一台网速正常且无任何网络端口限制的电脑进行测评;2、移动设备无法兼容远程监考功能,请使用配备有可正常运作的摄像头的台式机或笔记本电脑,建议使用最新版本的Chrome,Fi…

【KO】前端面试四

以下是剩余题目的详细解答,结合前端知识体系和实际应用场景展开: 91. JS 放在 head 里和放在 body 里有什么区别? 对比维度 放在 <head> 放在 <body> 加载阻塞性 会阻塞页面渲染,需等待 JS 下载/执行完成后,才继续渲染页面 一般放在 </body> 前,页面渲…

[Vid-LLM] 数据集 | 基准测试

第5章&#xff1a;数据集与基准测试 在前一章中&#xff0c;我们探讨了**视频大语言模型(Vid-LLMs)**能够执行的各种"工作"或"功能"&#xff0c;从视频总结到充当智能代理。 我们了解了它们的构建方式和扮演的角色。 但这里有个关键问题&#xff1a;这些惊…

34、扩展仓储管理系统 (跨境汽车零部件模拟) - /物流与仓储组件/extended-warehouse-management

76个工业组件库示例汇总 扩展仓储管理系统 (跨境汽车零部件模拟) 概述 这是一个高级的仓储管理系统 (WMS) 模拟组件&#xff0c;专为展示跨境汽车零部件的复杂物流场景而设计。它模拟了从海外供应商发货&#xff0c;经过海运/空运、清关、质检&#xff0c;到最终入库上架&am…

nodejs koa留言板案例开发

包含功能 登录注册(不开放注册只是用固定的账号信息) 查看列表 查看详情 发布信息 编辑信息 删除信息 项目接口 npm init -y npm install koa --save npm istall koa-router --save (旧版本) 或者 npm install koa/router --save &#xff08;新版本&#xff09; npm instal…

4+ 图论高级算法

强连通分量 基础概念 强连通&#xff1a;在有向图 GGG 中&#xff0c;如果两个点 uuu 和 vvv 是互相可达的&#xff0c;即从 uuu 出发可以到达 vvv , 从 vvv 也可以到达 uuu , 则称 uuu 和 vvv 是强连通的。如果 GGG 中任意两个点都是互相可达的&#xff0c;则称 GGG 是强连通图…

从罗永浩访谈李想中学习现代家庭教育智慧

引言 在这个信息爆炸的时代&#xff0c;每个父母都在寻找培养孩子的最佳方式。在罗永浩与理想汽车创始人李想的深度访谈中&#xff0c;我们看到了一个成功企业家童年成长的真实样本。李想的成长经历为现代家庭教育提供了许多值得深思的启示。 一、正义感与乐观精神的种子 李想回…

AI实现超级客户端打印 支持APP 网页 小程序 调用本地客户端打印

核心思路都是&#xff1a;需要一个安装在用户电脑上的“中间人”程序&#xff08;本地客户端&#xff09;来接管打印任务&#xff0c;然后通过某种通信方式命令这个客户端进行打印。下面我将分平台详细阐述各种实现思路、优缺点和适用场景。一、核心思路与公共组件&#xff1a;…

Java集合(Collection、Map、转换)

✅ 推荐使用 ❌ 已过时 1. Collection Collection 是集合框架的根接口之一&#xff0c;它是所有单列集合&#xff08;如 List、Set、Queue 等&#xff09;的公共父接口。Collection 接口定义了集合的基本操作&#xff0c;比如添加、删除、遍历等。 Collection ├── List │ …

全国网络安全知识竞赛有哪些

全国范围内有多种类型的网络安全知识竞赛&#xff0c;涵盖国家级、行业级、高校、青少年和企业等多个维度。以下是主要的网络安全知识竞赛分类及详细介绍&#xff1a;一、国家级网络安全竞赛"强网杯"全国网络安全挑战赛主办单位&#xff1a;中央网信办、河南省人民政…

系统架构设计师备考第1天——系统架构概述

一、架构本质与角色定位架构 系统的骨架 ✅ 核心作用&#xff1a; 决定系统的健壮性、生命周期、扩展性衔接需求与实现&#xff0c;保障早期质量 &#x1f468;&#x1f4bb; 架构师核心能力&#xff1a;能力维度具体要求技术掌控力精通基础技术&#xff0c;洞悉局部瓶颈决策设…

c#实现鼠标mousemove事件抽稀,避免大数据阻塞网络

这个封装类可以独立于具体的网络传输逻辑&#xff0c;为任何需要减少鼠标移动数据量的应用提供灵敏度和数据量优化。 核心优化功能 1. 灵敏度调整 // 减少微小移动的数据发送 (2, 1) 0.5 → (1, 0) // 忽略微小移动2. 移动累积 // 累积多次小移动&#xff0c;批量发送 (1, 0) …

机器学习 [白板推导](十三)[条件随机场]

​ 17. 条件随机场&#xff08;Conditional Random Field&#xff0c;CRF&#xff09; 17.1. 背景 机器学习分类模型中&#xff0c;有硬分类和软分类两种主流思想&#xff0c;其中硬分类模型有支持向量机SVM&#xff08;最大化几何间隔&#xff09;、感知机PLA&#xff08;误…

调味品生产过程优化中Ethernet/IP转ProfiNet协议下施耐德 PLC 与欧姆龙 PLC 的关键通信协同案例

案例背景在食品饮料行业&#xff0c;生产过程的精准控制对于保证产品质量和安全至关重要。某知名食品饮料企业的生产线上&#xff0c;前处理、灌装和包装环节采用了基于 ProfiNet 主站的施耐德 M340 系列 PLC 进行控制&#xff0c;以确保生产过程的稳定性和精确性。而原料仓储和…

Elasticsearch vs 单表LIKE查询性能对比

关键因素影响 1、索引结构&#xff1a; .Elasticsearch使用倒排索引&#xff0c;特别适合文本搜索 .传统数据库即使有索引&#xff0c;对LIKE %keyword%这种模式也无法有效利用 2、查询复杂度&#xff1a; .简单查询&#xff1a;ES快5-10倍 .复杂组合查询&#xff1a;ES可能快1…

如何通过WordPress联盟营销获取潜在客户

您是否经营着一个销售周期较长的业务&#xff1f; 那么你就会知道&#xff0c;从首次访问者那里获得立即销售的机会是很少见的。 当然&#xff0c;您的潜在客户在进行重大投资之前需要时间进行研究、比较各种方案并建立信任。这时&#xff0c;联盟营销线索挖掘就成为您的秘密…