真值和机器数及机器数的相互转换关系
一:真值和机器数定义
1.真值
真值是指在数值前面用“+”号表示正数,用“-”号表示负数的带符号二进制数。
2.机器数
机器数(又称为机器码)是指在数字系统中用“0”表示符号“+”,用“1”表示符号“-”,即把符号“数值化”后的带符号二进制数。常用的机器数有原码、反码和补码。
二、3种常用机器数
1.原码
求取方法:符号位用0表示正,用1表示负;数值位不变,即与真值的数值位相同。
例如,若x=0.1011、y=–10110,则
[x]原码=0.1011(由于x为正数,所以符号位为0,数值位与真值相同)
[y]原码=110110(由于y为负数,所以符号位为1,数值位与真值相同)
特点:求取方便,运算不方便,“0”有“+0”和“-0”两种不同形式。
2.反码
求取方法:符号位用0表示正,用1表示负。数值位与符号位相关,当为正数时,数值位不变,即与真值的数值位相同;当为负数时,数值位是真值的数值位按位取反(0变为1,1变为0)。
例如,若x=-0.1010、y=+10101,则
[x]反码=1. 0101(由于x为负数,所以符号位为1,数值位为真值的数值位按位变反)
[y]原码=010101(由于y为正数,所以有符号位为0,数值位与真值相同)
特点:求取较方便,运算较方便(可以将减法运算转化为加法运算),“0”有“+0”和“-0”两种不同形式。
3.补码
求取方法:符号位用0表示正,用1表示负。数值位与符号位相关,当为正数时,数值位不变,即与真值的数值位相同;当为负数时,数值位是真值的数值位按位取反,并在末位加1。
例如,若x=-11010、y=+0.1010,则
[x]补码=100110(由于x为负数,所以符号位为1,数值位为真值的数值位按位变反,末位加1)
[y]补码=0.1010(由于y为正数,所以有符号位为0,数值位与真值相同)
特点:运算方便(可以将减法运算转化为加法运算),“0”只有“+0”一种形式。
三:机器码求法对比
四、真值、原码、反码、补码的相互转换
带符号二进制数的真值、原码、反码和补码之间的相互转换如图1所示。
图1 真值、原码、反码和补码之间的相互转换
最后让我们来做一个练习
题目
答案
see you!
__EOF__

本文链接:https://www.cnblogs.com/getup/p/12989127.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)