分享读C Primer Plus时遇到的一个问题(补档5月7日)
最近在学习C Primer Plus。书中第66页,3.8 关键概念 这一小节中有这一段话:
“计算机中的浮点数和整数在本质上不同,其存储方式和运算过程有很大区别。即使两个 32 位存储单元存储的位组合完全相同,但是一个解释为 float 类型,另一个解释为 long 类型,这两个相同的位组合表示的值也完全不同。例如,在 PC 中,假设一个位组合表示 float 类型的数 256.0,如果将其解释为 long 类型,得到的值是 113246208。C 语言允许编写混合数据类型的表达式,但是会进行自动类型转换,以便在实际运算时统一使用一种类型。“
我自己的理解是:有两个长度为32位的存储空间有同样的位组合,它们分别存储了 float 和 long 两种类型。但因为 float 和 long 在计算机中的存储方法和形式不同,导致了输出的值不同。
抛出问题:在验算中我得出的 long 类型的结果为 1132462080,和原文结果不同,较书上数字多了一位 0。
首先探讨 float 数据类型的存储形式。
浮点型变量在计算机内存中占用4个字节(4 Byte),即32-bit。这 32 位的存储空间为SEEE EEEE EMMM MMMM MMMM MMMM MMMM MMMM 的格式。
S部分:数符。表示浮点数的正负,1为负数,0为正数。
E部分:阶码。指数加上127后的值的二进制数。
M部分:尾数。规格化表示后底数去除整数位1的二进制数。

Single precision单精度浮点数和 float 浮点数存储形式相同
*规格化的步骤:
(1)将 float 转化为二进制形式。
(2)用科学计数法表示第一步得到的二进制数,得到的指数加127既是E部分的阶码。
(3)科学计数法的小数部分,即M部分的尾数。

最后可以得到浮点数256.0的存储形式:
0100(SEEE) 0011(EEEE) 1000(EMMM) 0000(MMMM)
0000(MMMM) 0000(MMMM) 0000(MMMM) 0000(MMMM)
32位的存储空间里包含了1个S,代表正负;8个E为指数。实质上就是这个浮点数其数值的数量级;23个M,即这个数本身由哪些数字组成。
实质上这个32位存储空间就是科学记数法的二进制”变种“,它包含了正负、数字和数量级,即表示了一个数。
#两点补充:(1)为什么要给指数加127才是阶码?答:浮点数的指数可正可负,指数E的存储空间是带符号的8位。所以根据IEEE标准,float 的指数取值范围为 -126 到 128,需要加上127来取消负数情况。(2)为什么尾数是规格化后底数去掉整数位 1 的二进制数?答:科学记数法后底数部分实际是占用24bit 的一个值,但是最高位始终为1。所以最高位省去不存储,在存储中占23bit。
关于 long 长整型数的存储格式,我并没有查到太多的相关资料,大多都是与 int、long long 相关等等。因该就是除了原码、反码、补码相关知识之后,直接首位表正负,其他二进制码就是它的数值。
所以把浮点数 256.0 的 32 位存储形式0100 0011 1000 0000 0000 0000 0000 0000转化为 long 得到 1132462080,而非书上的 113246208 。

这篇文章的本意是借此机会,来记录一下学习了数据类型存储形式和方法的知识成果。如果能有大神解决了我的问题,那更是再好不过!附上一条帮助我很多的博客的链接:https://www.cnblogs.com/chris-cp/p/4321793.html#undefined
分享读C Primer Plus时遇到的一个问题(补档5月7日)的更多相关文章
- [分享] 从定制Win7母盘到封装详细教程 By BILL ( 10月23日补充说明 )
[分享] 从定制Win7母盘到封装详细教程 By BILL ( 10月23日补充说明 ) billcheung 发表于 2011-10-23 00:07:49 https://www.itsk.com ...
- 开机时自动启动的AutoHotkey脚本 2019年10月09日
;;; 开机时自动启动的AutoHotkey脚本 2019年10月09日;; http://www.autoahk.com/archives/16600; https://www.cnblogs.co ...
- sql 计算两时间或日期 的相差的 年、 月、 日、时、分、秒,年、月、日分别的提取
--年.月.日.时.分.秒 datediff(yy,date1,date2) datediff(m,date1,date2) datediff(d,date1,date2) datediff(hh,d ...
- 开机时自动启动的AutoHotkey脚本 2019年07月08日19时06分
;;; 开机时自动启动的AutoHotkey脚本;; 此脚本修改时间 2019年06月18日20时48分;; 计时器创建代码段 ------------------------------------ ...
- struts2练习时犯的错误(2016年11月4日)
1.Tomcat启动时报错 严重: 文档无效: 找不到语法. at (null:3:8) org.xml.sax.SAXParseException; systemId: file:/F:/Progr ...
- 微信公众号的分享接口,分享提示config:fail,invalid signature的解决办法(2017年12月)
微信中打开网页,使用微信右上角菜单中自带的分享功能的经历及总结: 最开始,微信分享页面时,直接读取页面的标题(title)和页面中的第一张符合条件的图片[此种方式在2017-03-29之前管用,这一天 ...
- 自学C Primer Plus时还没想明白的问题
2016年11月24日 1. 计算机中两个浮点数怎样进行加法运算.2. 为什么计算机在计算时存在损失精度的可能3. 无符号数和有符号数的运算是怎样的4. printf中使用格式控制符的截断问题,比如% ...
- 安装dede UTF_8时报出了一个致命错误和警告,最后不能显示网站后台和首页了
安装dede UTF_8时报出了一个致命错误和警告,最后不能显示网站后台和首页了.报错如下: 登陆首页显示:Fatal error: Call to undefined function ParCv( ...
- Java 获取各时区时间,获取当前时间到格林威治时间1970年01月01日00时00分00秒的秒数
格林威治时间即UTC/GMT时间,1970年01月01日00时00分00秒(即UTC+8的北京时间1970年01月01日08时00分00秒)计算代码如下: /** * 获取指定时间到格林威治时间的秒数 ...
随机推荐
- [題解]luogu_P1052 過河
來源:題解 不發題面 因為 l 範圍太大,而石子數卻很少,步數也僅僅在1~10之間, 也就是說兩個石子之間很有可能間隔很大的距離,不管怎麼跳都能跳過去,那麼中間那些怎麼樣都能跳過去的區間和沒有等價, ...
- 最新Centos7安装python3并与python2共存
1.查看是否已经安装Python CentOS 7.2 默认安装了python2.7.5 因为一些命令要用它比如yum 它使用的是python2.7.5. 使用 python -V 命令查看一下是否安 ...
- (bzoj1337 || 洛谷P1742 最小圆覆盖 )|| (bzoj2823 || 洛谷P2533 [AHOI2012]信号塔)
bzoj1337 洛谷P1742 用随机增量法.讲解:https://blog.csdn.net/jokerwyt/article/details/79221345 设点集A的最小覆盖圆为g(A) 可 ...
- 103 Binary Tree Zigzag Level Order Traversal 二叉树的锯齿形层次遍历
给定一个二叉树,返回其节点值的锯齿形层次遍历.(即先从左往右,再从右往左进行下一层遍历,以此类推,层与层之间交替进行).例如:给定二叉树 [3,9,20,null,null,15,7], 3 ...
- hdu1754I Hate It(splay)
链接 线段树的水题,拿来学习一下splay. 本题涉及到求最大值以及单点更新,折腾了许久,差不多把splay搞明白了. 按位置建树,按位置是一颗排序二叉树,对于区间的操作非常方便,每次操作都将需要的结 ...
- CImage访问像素及其像素操作总结
MSDN的代码 COLORREF pixel; int maxY = imgOriginal.GetHeight(), maxX = imgOriginal.GetWidth(); byte r,g, ...
- Notepad++设计Tab制表符为4个空格
Notepad++中,常常需要将一个Tab制表符转换成4个空格.这种情况大多发生在对空白检查严格的情况下,比如Python程序. 设置 → 首选项 → 制表符设置 → 勾选“ 转换为空格 ”.
- POJ Washing Clothes 洗衣服 (01背包,微变型)
题意:有多种颜色的衣服,由两个人合作来洗,必须洗完一种颜色才能洗下一种,求需要多少时间能洗完. 思路:将衣服按颜色分类,对每种颜色进行01背包,容量上限是该种颜色衣服全部洗完的耗时长一半,其实就是在最 ...
- 洛谷 P2347 砝码称重 != codevs 2144
题目描述 设有1g.2g.3g.5g.10g.20g的砝码各若干枚(其总重<=1000), 输入输出格式 输入格式: 输入方式:a1 a2 a3 a4 a5 a6 (表示1g砝码有a1个,2g砝 ...
- UVA - 12264 Risk (二分,网络流)
题意比较坑,移动完以后的士兵不能再次移动,不然样例都过不了... 最小值最大满足决策单调性所以二分答案,跑网络流验证是否可行. 这种题重点在建图,为了保证只移动一次,拆点,一个入点一个出点,到了出点的 ...