体育资讯网

您现在的位置是:首页 > 分类12 > 正文

分类12

2的源码和0的源码一样吗(0有两种原码)

hacker2022-07-14 17:24:25分类1284
本文目录一览:1、请问原码和源码有什么区别?2、数字0的原码为B、B

本文目录一览:

请问原码和源码有什么区别?

原码(true form)是一种计算机中对数字的二进制定点表示方法。原码表示法在数值前面增加了一位符号位(即最高位为符号位):正数该位为0,负数该位为1(0有两种表示:+0和-0),其余位表示数值的大小。

源码就是指编写的最原始程序的代码。运行的软件是要经过编写的,程序员编写程序的过程中需要他们的"语言"。音乐家用五线谱和音符,建筑师用图纸和笔,那程序员的工作的语言就是"源码"了。

二者区别由此可见。

数字0的原码为 B、 B

[+0]原码=0000 00002的源码和0的源码一样吗, [-0]原码=1000 0000[+0]反码=0000 00002的源码和0的源码一样吗, [-0]反码=1111 1111[+0]补码=0000 0000, [-0]补码=0000 0000补码没有正0与负0之分。

正数的反码、补码和其源码相同,负数的反码是其源码,除符号位外其2的源码和0的源码一样吗他位取反负数的补码是取其反码后加1。详细释义:所谓原码就是二进制定点表示法,即最高位为符号位,“0”表示正,“1”表示负,其余位表示数值的大小。(一)反码表示法规定:

1、正数的反码与其原码相同2的源码和0的源码一样吗

2、负数的反码是对正数逐位取反,符号位保持为1;(二)对于二进制原码10010求反码:((10010)原)反=对正数(00010)原含符号位取反= 反码11101 (10010,1为符号码,故为负)(11101) 二进制= -2 十进制(三)对于八进制

+0或者-0的源码、反码、补码

[+0]原码=0000 0000,   [-0]原码=1000 0000

[+0]反码=0000 0000,   [-0]反码=1111 1111

[+0]补码=0000 0000,   [-0]补码=0000 0000

你会发现,+0和-0的补码是一样的。即 0的补码只有一种表示。

这里解释一下[-0]补码是怎么得来的。

负数的补码就是反码整体加一。符号位上的进位舍弃。(所以,舍弃了符号位的补码的第一位是数值位,不是符号位,符号位舍弃了)

另外解释一下原码符号位和补码符号位的关系,补码的符号位不是保持原码的第一位不变,而是 符号位不变,[-0]反码的第一个1是符号位,尾数中的7个1是数值位,尾数加一后,数值位产生了进位,1111 1111+1=1 0000 0000(计算补码的过程中,并不是先保证第一位不变,而是保证符号位不变,保证补码规则是反码整体加一)。

所以,补码能表示的数的个数中,比原码反码少了一个,所以补码可以多表示一个真值为-128的数。

但是,多表示的这个数-128比较特殊,只有原码和补码,没有反码。

-128的补码是1000 0000。128的补码为什么是1000 0000。因为8位二进制的原值表达范围为:-127至127,共有256个组合序列 0000 0000 至1111 1111 。+128的原值在8位中是表达不出来的。

扩展资料:

数值在计算机中是以补码的方式存储的,在探求为何计算机要使用补码之前, 让我们先了解原码, 反码和补码的概念。

对于一个数, 计算机要使用一定的编码方式进行存储。 原码, 反码, 补码是计算机存储一个具体数字的编码方式。

一个数在计算机中的二进制表示形式, 叫做这个数的机器数。

机器数是带符号的,在计算机用一个数的最高位存放符号, 正数为0, 负数为1。比如,十进制中的数 +2 ,计算机字长为8位,转换成二进制就是[00000010]。如果是 -2 ,就是 [10000010] 。

因为第一位是符号位,所以机器数的形式值就不等于真正的数值。例如上面的有符号数 [10000010],其最高位1代表负,其真正数值是 -2 而不是形式值130([10000010]转换成十进制等于130)。

所以将带符号位的机器数对应的真正数值称为机器数的真值。

参考资料:

原码_百度百科

反码_百度百科

补码_百度百科

计算机的原码,反码,补码是怎么回事?可以举例说明吗?

原码、反码和补码是计算机中对数字二进制的三种表示方法。

1、原码

原码(true

form)是一种计算机中对数字的二进制定点表示方法。原码表示法在数值前面增加了一位符号位(即最高位为符号位):正数该位为0,负数该位为1(0有两种表示:+0和-0),其余位表示数值的大小。

例如:用8位二进制表示一个数,+11的原码为00001011,-11的原码就是10001011。

2、反码

反码是数值存储的一种,多应用于系统环境设置,如linux平台的目录和文件的默认权限的设置umask,就是使用反码原理。反码的表示方法是:正数的反码与其原码相同;负数的反码是对正数逐位取反,符号位保持为1。

例如:

[+7]反=

0000111

B;

[-7]反=

1

1111000

B。

3、补码

正数:正数的补码和原码相同。负数:负数的补码则是符号位为“1”。并且,这个“1”既是符号位,也是数值位。数值部分按位取反后再在末位(最低位)加1。也就是“反码+1”。

例如:

[+7]补=

0000111

B;

[-7]补=

1

1111001

B。

扩展资料

原码、反码、补码的转换方法如下:

(1)

已知原码,求补码。

例:已知某数X的原码为10110100B,试求X的补码和反码。

首先通过原码的首位确定该数字的正负,若为正数,反码与原码相同,补码比原码在末尾加1;若为负数,求其反码时,符号位不变,数值部分按位求反;求其补码时,再在其反码的末位加1。

(2)已知补码,求原码。

按照求负数补码的逆过程,数值部分应是最低位减1,然后取反。但是对二进制数来说,先减1后取反和先取反后加1得到的结果是一样的,故仍可采用取反加1的方法。

参考资料来源:百度百科-反码

参考资料来源:百度百科-补码

参考资料来源:百度百科-原码

发表评论

评论列表

  • 温人俛就(2022-07-15 04:58:21)回复取消回复

    ]补码是怎么得来的。负数的补码就是反码整体加一。符号位上的进位舍弃。(所以,舍弃了符号位的补码的第一位是数值位,不是符号位,符号位舍弃了)另外解释一下原码符号位和补码符号位的关系,补码的符号位不是保持原码的第一位不变,而是 符号位不变,[-0]反码的第一个1是符号位,尾数中的7个1是数值位,尾数

  • 断渊云胡(2022-07-15 01:46:26)回复取消回复

    扩展资料原码、反码、补码的转换方法如下:(1)已知原码,求补码。例:已知某数X的原码为10110100B,试求X的补码和反码。首先通过原码的首位确定该数字的正负,若为正数,反码与原码相同,补码比原码在末尾加1;若为负数,求其反码时,符号位不变

  • 假欢常安(2022-07-15 04:24:10)回复取消回复

    即最高位为符号位):正数该位为0,负数该位为1(0有两种表示:+0和-0),其余位表示数值的大小。例如:用8位二进制表示一个数,+11的原码为00001011,-11的原码就是10001011。2、反码反码是数值存储的一种,多应用于系统环境设置,如linux平台的目录和文件的默认

  • 拥嬉莺时(2022-07-14 20:44:30)回复取消回复

    ;负数的反码是对正数逐位取反,符号位保持为1。例如:[+7]反=0000111B;[-7]反=11111000B。3、补码正数:正数的补码和原码相同。负数:负数的补码则是符号位为“1”。并且,这个“1”既是符号位,也是数值位。数值部分按位取反后再在末

  • 边侣海夕(2022-07-14 23:14:33)回复取消回复

    。一个数在计算机中的二进制表示形式, 叫做这个数的机器数。机器数是带符号的,在计算机用一个数的最高位存放符号, 正数为0, 负数为1。比如,十进制中的数 +2 ,计算机字长为8位