浮点数 在计算机内的存储形式
发布网友
发布时间:2022-04-22 06:47
我来回答
共2个回答
热心网友
时间:2022-06-16 19:36
浮点数不难,但是要想记熟还真有点不容易,多琢磨琢磨。
一般情况下,浮点数的表示有一下几个要点:
1、要规格化(让浮点数表示结果唯一),因为100=10^2 = 0.1 * 10^3, 所以第一步要统一地规格化,确定“阶数”和“尾数”(尾数在0.5-1之间,也就是二进制的0.1-1.0之间)
2、“阶码”一般用“移码”表示法,而“尾数”一般用“原码/补码表示法,“数符”表示浮点数的正副号
3、浮点数的形式: “符号位”【应该就是‘数符’】+“阶码”+“尾数“
--浮点数的表示按照不同地标准,表示方法不同,你的原问题没讲清楚用什么格式表示,我就用最常用地格式来理解了
------------------
其实就以上两点,计算机中“‘帯符号数’的表示”有四种:原码、补码、反码、移码,这些都是基础知识,可以自己去看一下这四种表示方法,就自然明白“阶符、数符”这些相当于“符号位”的作用了。
先简单讲一下吧,你再结合详细资料看吧:【设所表示的都是定点纯小数】
(小数点前面可以看成是“符号位”,也就对应原来地“阶符”和“数符”)
原码:0.11表示0.75(2^-1 + 2 ^-2), 1.11表示 ‘-0.75’(前面的1相当于符号位,表示这个数是负数,也就是说“符号位是0”表示正数,1表示负数)
补码:最普遍地就是补码了 0.11表示0.75, 1.11表示‘-0.25’(也是“0”为正数,1为负数。和原码地规律一样)
反码,最简单了:正数不变,负数对每一位‘取反’即可,0.11=0.75,1.10=-0.25(即0.01地相反数)
-------------以上三种表示方法,对正数的情况都不做处理,但是移码表示法要对正数做处理。
移码:1.01=0.25,而0.01=-0.75
。移码复杂一点,他的表示方法是: 移码= 2^阶码位数 + 真值(真值:指原来那个‘帯符号数’,注意要把把正副号带入计算)
-----------------------------------
N=-0.110101x2^100: 阶数是“正100”,尾数是“负0.110101”,所以整个浮点数是个负数,所以第一位是“1”【第一个符号位-“数符”表示‘尾数的正负号’】
阶码是“10 0100”【移码表示法,最高位是“符号位”】
所以,应该表示为: 1(符号位) 100100(阶码的移码表示) 11010100【尾数和符号位结合起来,用的是原码表示法】
热心网友
时间:2022-06-16 19:36
一般来说,浮点数在计算机内都是按照IEEE 754所规定的格式存储的。
按照IEEE 754规范,一个长度为W的字(word),其中的位元按照从0到W−1的整数编码(即小端模式),于是MSB(最高效位元)为符号位,其后是指数部分,最后是小数部分。
指数部分是经过指数偏差之后显示的数据。
小数部分即小数点后的有效部分。