第三组程序和数据机器级表示.pptxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 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

文档评论(0)

moon8888 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档