1.正数的正数原码,补码,码相码反码是同正什么?
2.为什么正数的反码和其源码相同啊?
3.源码,反码,补码是什么东西,怎么转化的?
4.正数的原码、反码、源码补码相同,相同为什么?
正数的原码,补码,正数反码是码相码什么?
[+0]原码= , [-0]原码=[+0]反码= ,同正 [-0]反码=
[+0]补码= ,源码 [-0]补码=
补码没有正0与负0之分。相同正数的关系反码、补码和其源码相同,正数负数的码相码反码是其源码,除符号位外其他位取反负数的同正补码是取其反码后加1。
详细释义:
所谓原码就是二进制定点表示法,即最高位为符号位,“0”表示正,“1”表示负,其余位表示数值的大小。
(一)反码表示法规定:
1、源码材料正数的反码与其原码相同;
2、负数的反码是对正数逐位取反,符号位保持为1;
(二)对于二进制原码求反码:
(()原)反=对正数()原含符号位取反= 反码 (,1为符号码,故为负)
() 二进制= -2 十进制
(三)对于八进制:
举例 某linux平台设置了默认的目录权限为(rwxr-xr-x),八进制表示为,那么,umask是权限位的反码,计算得到umask为的过程如下:
原码= 反码 (逐位解释:0为符号位,0为7-7,2为7-5,茄子源码2为7-5)
(四)补码表示法规定:正数的补码与其原码相同;负数的补码是在其反码的末位加1。
扩展资料
转换方法
由于正数的原码、补码、反码表示方法均相同,不需转换。在此,仅以负数情况分析。
(1) 已知原码,求补码。
例:已知某数X的luabridge源码原码为B,试求X的补码和反码。
解:由[X]原=B知,X为负数。求其反码时,符号位不变,数值部分按位求反;求其补码时,再在其反码的末位加1。
1 0 1 1 0 1 0 0 原码
1 1 0 0 1 0 1 1 反码,符号位不变,数值位取反
1 +1
1 1 0 0 1 1 补码
故:[X]补=B,源码ollydbg[X]反=B。
(2) 已知补码,求原码。
分析:按照求负数补码的逆过程,数值部分应是最低位减1,然后取反。但是对二进制数来说,先减1后取反和先取反后加1得到的结果是一样的,故仍可采用取反加1 有方法。
例:已知某数X的补码B,试求其原码。
解:由[X]补=B知,X为负数。
采用逆推法
1 1 1 0 1 1 1 0 补码
1 1 1 0 1 1 0 1 反码(末位减1)
1 0 0 1 0 0 1 0 原码(符号位不变,数值位取反)
百度百科 反码
为什么正数的反码和其源码相同啊?
计算机用 反码,是为了做减法 可以用硬件(集成电路)加法器实现。
正数加正数,不用变化,直接送入加法器。
正数加负数:
正数减一个数,等于加 原数的负数,等于加它的反码。
负数才有反码。负数才需要有反码。
正数没有反码,或不需要反码。为了定义上的完整,约定:正数的反码和其源码相同。
源码,反码,补码是什么东西,怎么转化的?
正数的原码,补码,反码都相同,都等于它本身
负数的补码是:符号位为1,其余各位求反,末位加1
反码是:符号位为1,其余各位求反,但末位不加1
也就是说,反码末位加上1就是补码
正数的原码、反码、补码相同,为什么?
正数的原码、反码、补码相同;
负数的原码取反就是反码(最高位1不能变),反码+1就是补码;
负数的补码取反就是反码(最高位1不能变),反码+1就是原码;
因为最高bit不是1,所以这里Y一定是正整数。
如果X是无符号数:
X和Y的补码就是源码,直接相减的到结果是整数,也是补码,
X-Y=
如果X是有符号数:
X的原码是,即-,Y的原码是,即,X-Y为-,得到的原码,对应的补码是