浮点数笔记

关于浮点数问题相信大家早就耳濡目染了,但是为什么会出现这总情况呢?今天我们就来探究一下这个问题。


image.png

基础复习

在探究这个问题之前,我们先复习一下计算机基础的知识

  • 怎么将十进制浮点数转化为二进制
  • 浮点数在计算机中如何存储的
  • 计算机怎么计算加法
  • 计算机怎么计算减法

怎么将小数十进制转化为二进制

计算方法:乘2取整的逆序(value*2 取整数,然后将小数继续 * 2 ,直到结果为1.0,然后把整数逆序过来)
float.map((item)=> parseInt(item * 2)).revese()

小于1的浮点数

举个例子:0.125
0.75 * 2 = 1.5 => 1
0.5 * 2 = 1.0 => 1
结果就是0.11

大于1的浮点数

大于1的浮点数需要两步

  • 第一步:将整数部分转换为二进制(辗转相除法--除以进制数取余数然后逆序),这个较简单这里不说
  • 第二步:将小数部分转换为二进制(方法见上)
    例子:5.125
    第一步:整数转二进制
    5/2 = 2···1
    2/2 = 1···0
    1/2 = 0···1
    所以整数部分就是101
    第二步:小数部分转二进制
    0.125 * 2 = 0.25 => 0
    0.25 * 2 = 0.5 => 0
    0.5 * 2 = 1.0 => 1
    所以小数部分就是0.001

合起来 5.125 转化为二进制为 101.001。下面已图为证,在在线工具做的计算。

image.png

浮点数在计算机中的存储方式

首先我们应该知道一般浮点数分为单精度和双精度,比如在Java里面单精度用float来表示数据类型,而double来表示双精度,可是何为单精度何为双精度,单精度精度到多少,双精度又精度到多少呢?当我们清楚了浮点数在计算机中怎么存储的就明白了。

我们常说电脑的32位,64位跟这个就是有关系的。32位就是32个bit,8个bit等于一个byte(字节),那么32bit就是4个字节,也就是说用4个字节来存储一个数,这就是单精度。而双精度就是用64位,8个字节来存储数,这就是双精度。

那么精度是多少呢?

对于这个问题我们要知道计算机的二进制表示是遵循IEEE浮点数表示法。这种结构是一种科学计数法,用符号、指数和尾数来表示,底数定为2——即把一个浮点数表示为尾数乘以2的指数次方再添上符号。
下面是具体的规格:

占位 符号位 阶码 尾数 长度
float 1 8 23 32
double 1 11 52 64

在这里我们可以看到三个名词:符号位、阶码、尾数

  • 符号位:用来表示正负(正数符号位为0,负数符号位为1)。
  • 阶码:阶码跟指数有很大的关系。另外一个相关名词,阶码基数,单精度为127(01111111),双精度为1023(01111111111)
  • 尾数:尾数其实就是精度了。所以单精度精确到小数点后23位,而双精度精确到小数点后52位
单精度存储方式

双精度存储方式

看到这里我相信应该已经有点感觉了,我再举个例子,我相信应该就能明白了。

还是拿0.75来举例吧,单精度简单一下,以32为计算,64位同理。0.75的二进制是0.11,转换为IEEE浮点数表示法为:1.1 * 2^-1。
我们还需要知道一点,阶码的值 = 阶码基数 + 指数 = 127 + (-1) = 126 ,拿到刚才那个网站计算一下,126 = 01111110


image.png

而1.1由于二进制整数部分都是1,所以去掉1留下0.1作为尾数部分(因为都是1点多的形式,所以这个1就没必要存了),所以尾数部分就是 1000 0000 0000 0000 0000 000
加上符号位0.75在32位的表示为:0011 1111 0100 0000 0000 0000 0000 0000(粗体为指数部分,斜体为尾数部分)

计算机怎么计算加法

计算机怎么计算乘法

参考

为什么0.1 + 0.2不等于0.3?
浮点数在计算机中存储方式

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,163评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,301评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,089评论 0 352
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,093评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,110评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,079评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,005评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,840评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,278评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,497评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,667评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,394评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,980评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,628评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,649评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,548评论 2 352