- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
第三组
程序及数据的机器级表示
樊朝辉 孙懿 黄杰 任成琨 黄章冠 潘鑫 王嘉琦 杨玉茹
整数的除运算
1
整数除0和浮点数除0的问题
2
浮点数舍入问题
3
目录
CONTENTS
01.整数的除运算
针对下列两个小程序,给出运行结果,并解释为什么?利用你所掌握的反汇编调试工具,佐证你的观点。
整数的除运算
这两个结果或许大家都感到很诧异,下面我们通过汇编代码来研究到底发生了什么
Linux下两段代码运行情况:
代码一:
程序在汇编中解释为neg(取反)
Tmin取反后还是其本身,不会溢出
整数的除运算
格式:NEG OPR
执行的操作:(OPR)-- —(OPR)
亦即把操作数按位求反后末位加1,因而执行的操作也可表示为:
(OPR)-- 0FFFFH — (OPR) + 1
NEG指令对标志的影响与用零作减法的SUB指令一样。
整数的除运算
这两个结果或许大家都感到很诧异,下面我们通过汇编代码来研究到底发生了什么
Linux下两段代码运行情况:
代码二:
程序在汇编中解释为idivl(除法)
Tmin/-1 = TMax+1,发生溢出,程序中断。
整数的除运算
整数的除运算
这两个结果或许大家都感到很诧异,下面我们通过汇编代码来研究到底发生了什么
Linux下两段代码运行情况:
代码二:
将断点设置在除法进行的地方,调试如图所示,抛出异常,程序终止
02.整数除0和浮点数除0的问题
代码示例
//代码段一
#include stdio.h
int main()
{
int a=1, b=0;
printf (Division by zero:%d\n, a/b);
return 0;
}
//代码段二
#include stdio.h
int main()
{
double x=1.0, y=-1.0, z=0.0;
printf (Division by zero:%f%f\n, x/z, y/z);
return 0;
}
运行结果
运行结果
解释
从通用概念来说,除0本来就是不允许的,即使允许,它的值也应该是无穷大。
int值采用的补码通用表示法,使得它表示的整数范围有限,无法表示无穷大这一概念;
而根据IEEE浮点表示法,有正无穷和负无穷的表示,即指数全1和尾数全0,所以可以不报错,而从得到的结果正负无穷来指示结果出错。
浮点数中的INF
#INF / inf:这个值表示“无穷大 (infinity 的缩写)”,即超出了计算机可以表示的浮点数的最大范围(或者说超过了 double 类型的最大值)。
例如,当用 0 除一个整数时便会得到一个#INF / inf值;相应的,如果用 0 除一个负整数也会得到 -#INF / -inf 值。
简而言之,如果遇到 #INF / inf,就检查是否发生了运算结果溢出除零。
Gdb调试 – 代码段一
重启动标志RF用来控制是否接受调试故障。规定:RF=0时,表示“接受”调试故障,否则拒绝之。在成功执行完一条指令后,处理机把RF置为0,当接受到一个非调试故障时,处理机就把它置为1。
不能执行return 0,说明程序异常中断
Gdb调试 – 代码段二
执行return 0,说明程序没有异常中断
没有出现标志位RF。
03.浮点数舍入问题
例:将同一实数分别赋值给单精度和双精度类型变量,然后打印输出。
#include stdio.h
main(){
float a;
double b;
a = 123456.789e4;
b = 123456.789e4;
printf(“%f/n%f/n”,a,b);
}
运行结果如下:
1234567936.000000
1234567890.000000
问题:为什么同一个实数赋值给float型变量和double型变量,输出结果会有所不同呢?
舍入
由于表示方法限制了浮点数的范围和精度,浮点运算只能近似地表示实数运算。因此对于某一值x,我们想要用一种系统的方法,用浮点形式表示最接近的值,这就是舍入。
向偶数舍入是默认的方式,也被称为最接近的值的舍入。其采取的方法是对于两个可能结果正中间的值,将数字向上或者向下舍入,使得结果的最低有效数字是偶数,在二进制表示中最低有效位的值0认为是偶数,1认为是奇数。
例如舍入到二进制小数点右边1位。
10.010舍入后值为10.0
10.110舍入后值为11.0
舍入
s
exp
frac
31 30
23 22
0
现在来看一下本题中的数据:
1234567890=(010010011001011
您可能关注的文档
最近下载
- DIY烟油配方整理.xlsx VIP
- 2025中数联物流科技(上海)有限公司招聘笔试备考试题及答案解析.docx VIP
- 2025中国数联物流纪委办公室、巡视办公室相关岗位招聘笔试模拟试题及答案解析.docx VIP
- 开利VRV空调样册B-XCT-38VP-202106-02.pdf VIP
- 七年级(上)生物分组实验教案.pdf VIP
- 江苏省淮安市洪泽区洪泽外国语中学2024-2025学年九年级下学期3月月考语文试题(原卷版+解析版).docx VIP
- 2026年护士护理个人工作计划(三篇).pdf VIP
- 赤城县非凡矿业有限责任公司矿山地质环境保护与土地复垦方案.pdf VIP
- 2025《水下清淤机器人的结构方案设计》13000字(论文).docx
- [硕士]宣钢近北庄铁矿滑坡机理及稳定性分析.pdf VIP
原创力文档


文档评论(0)