【计算机组成原理】定点数和浮点数
创始人
2024-04-02 17:23:45
0

目录

一、概念

1. 定点数

1. 定点小数

2. 定点整数

3. 定点数表示的范围 

2. 浮点数 

1. 浮点数的表示形式 

2. 浮点数的表示范围 

3. 浮点数的规格化 

二、重点

1. 将十进制数转换为浮点数

2. 将浮点数转换为十进制数 


 

一、概念

1. 定点数

定点数表示法约定计算机中所有数据的小数点位置固定,其中,将小数点的位置固定在数据的最高位之前(或符号位之后)的数据表示称为定点小数,而将小数点固定在最低数位之后的数据表示称为定点整数。另外,由于小数点位置固定,因此小数点不必再用符号表示,其位置也无需存储。

1. 定点小数

设定点小数:x=X0.X1X2X3…Xn

① 符号位X0用来表示数的正负,小数点的位置是固定的,在计算机中不用去表示它。

② X1~Xn是数值的有效部分,也称尾数;X1为最高有效位。

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

2. 定点整数

设定点整数:x=X0X1X2…Xn

① 符号位X0用来表示正负。

② X1~Xn是数值的有效部分。

③ 小数点在Xn后面,可以省略掉。 

3. 定点数表示的范围 

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

① 机器字长。字长越长,其表示的数据范围就越大。

② 所采用的机器数表示方法。通过前面对几种不同机器数的分析可知,补码和移码表示所能表示的数据范围比原码和反码所能表示的数据范围要多一个数。 

2. 浮点数 

1. 浮点数的表示形式 

① 浮点数中的小数点位置并不固定,也就是小数点位置可以浮动,这也是浮点数得名的原因。

② 为了扩大浮点数的表示范围和提高其表示精度,二进制浮点数表示采用了类似十进制科学记数法的表示方法,任意一个二进制数N都可以表示成如下形式:N=2^E*M

③ 采用这种方法,二进制浮点数可表示成阶码E和尾数M两部分,其中阶码E是定点整数,而尾数M是定点小数。阶码的位数决定数据的表示范围,阶码的位数越多,能表示的数据范围就越大,而阶码的值决定了小数点的位置;尾数的尾数决定数据表示的精度。阶码长度相同时,分配给尾数的数位越多,数据表示的精度就越高。 

2. 浮点数的表示范围 

① 显然当阶码为最大值,尾数为最大值时,浮点数为正数最大值;而当阶码为最小值,尾数为正数最小值时,浮点数为正数最小值,这个值也就是浮点数的最小精度。同理,当阶码为最大值,尾数为最小负数时,浮点数为负数最小值;而当阶码为最小值,尾数为负数最大值时,浮点数为负数最大值。  

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

3. 浮点数的规格化 

① 同一浮点数可能存在多种表示形式,如0.01111*2^101还可以表示成0.11110*2^100。尾数小数点的位置不同,就会有不同的尾数和阶码组合,这将给浮点数的表示带来麻烦。为了使浮点数的表示形式唯一并进一步提高数据的表示精度,通常需要对浮点数进行规格化处理。

② 所谓规格化处理,就是使尾数真值最高有效位为1,也就是尾数的绝对值应大于等于0.1(二进制)或0.5(十进制)。 

二、重点

1. 将十进制数转换为浮点数

例:将十进制数20.59375转换成IEEE754单精度浮点数的十六进制机器码

① 首先我们要分别将整数和小数部分转换成二进制数:

20的二进制为10100,0.59375的二进制为0.10011,所以20.59375的二进制表示为10100.10011

② 移动小数点,使尾数变成1.M的形式(规格化):

10100.10011=1.010010011*2^4

③ 分析得:

S=0,E=e+127=4+127=131=10000011,M=010010011

所以32位浮点数的二进制存储格式为:

01000 0011010 0100 1100 0000 0000 0000
数符阶码尾数

 

 

 

④ 最终的机器码为:0100 0001 1010 0100 1100 0000 0000 0000

 对应的十六进制为:    4       1       A      4       C      0       0       0

2. 将浮点数转换为十进制数 

例:求IEEE754单精度十六进制浮点数(C1360000)对应的十进制

① 将十六进制数展开成二进制数为:1100 0001 0011 0110 0000 0000 0000 0000

② 从浮点数中分离出S、E、M:

S=1   符号位为:负 

E=100 0001 0

M=011 011

③ 计算得:e=E-127=00000011=3(十进制)

实际尾数为:1.M=1.011011

移动小数点,实际尾数为:1011.01

④ 将其转换为十进制数:1011是11,0.011是0.375,所以十进制数为 -11.375。

相关内容

热门资讯

文物界“出差天团”进京!猜猜这... 文物界“出差天团”进京!猜猜这些青铜界顶流会说啥?_北京时间现在上猫眼、美团、大众点评、微信,搜索“...
“十二星座”手动上新 全球首个... 转自:央视今天(14日)12时12分,我国在酒泉卫星发射中心使用长征二号丁运载火箭,成功将太空计算卫...
黑龙江开展全省跨境电商专题培训 转自:新华财经为提高黑龙江省商务主管部门跨境电商业务能力和跨境电商企业经营水平,推动传统外贸企业向跨...
西安鄠邑法院 | “最后一劝”... 保险公司:你在投保时就应当将被保险人之前出现过高热惊厥的病情如实告知给我们。岳鑫:我当时已经向保险业...
冀东水泥(000401.SZ)... 格隆汇5月14日丨冀东水泥(000401.SZ)公布2025年限制性股票激励计划(草案),本计划拟向...
网约车座椅靠背张贴“差评者得癌... 近日,有网友发帖称自己“五一”假期在杭州打网约车观看演唱会时,网约车前排座椅靠背张贴了一张“差评者得...
甘化科工:公司控股子公司沈阳含... 证券日报网讯甘化科工5月14日在互动平台回答投资者提问时表示,公司控股子公司沈阳含能生产的钨合金预制...
FOMC今年票委发话:4月低通... 芝加哥联储主席古尔斯比泼下冷水:最新CPI数据不一定反映出关税的真实影响,或许只是“尘埃飞扬”。芝加...
工行梧州藤县支行成功落地全辖首... 转自:新华财经近期,工行梧州藤县支行深入贯彻落实金融“五篇大文章”的工作部署,落实乡村振兴工作,将普...
爱迪特:公司保持开放态度,持续... 证券日报网讯爱迪特5月14日在互动平台回答投资者提问时表示,公司保持开放态度,持续关注口腔医疗及相关...
中航西飞:公司及子公司陕飞依托... 证券日报网讯中航西飞5月14日在互动平台回答投资者提问时表示,公司及子公司陕飞依托大中型飞机平台,持...
济宁市交通强国山东示范区建设推... 转自:济宁政务5月14日上午,济宁市交通强国山东示范区建设推进会议召开。济宁市委书记温金荣出席并讲话...
小马智行创始人自愿延长锁定期5... 5月14日,小马智行(NASDAQ:PONY)宣布,董事会主席、联合创始人、CEO彭军,以及联合创始...
北京博物馆头部达人联盟成立 5月14日,在“5·18国际博物馆日”中国主会场活动、北京博物馆季及“看·见殷商”展即将举行的重要时...
赵乐际分别会见拉丁美洲议会议长... 转自:北京日报客户端全国人大常委会委员长赵乐际14日在北京分别会见拉丁美洲议会议长冈萨雷斯、中美洲议...
在古老的意大利科莫歌剧院,廖昌... 转自:上观新闻意大利当地时间5月12日晚,拥有212年历史的意大利科莫歌剧院迎来2024-2025年...
2025 新能源五大标杆车型解... 转自:衡水日报在 2025 年新能源汽车技术呈 "井喷式" 发展的大背景下,消费者对车辆的核心诉求已...
紫光原董事长赵伟国被判死缓,紫... 【#紫光原董事长赵伟国被判死缓#,#紫光原董事长曾被称为并购狂人#,紫光集团破产重组后如何“求生”?...
为什么南方人家里都有这种碗? 作者:敏敏 徐可心编辑:陈燕妮如果你来到南方的街头吃饭,很可能会看到一种印着大公鸡的碗。小红书上就有...