二进制的原码、反码、补码及相关计算

1.二进制的最高位是符号位,0表示正数,1表示负数
2.正数的原码、反码、补码都一样
3.负数的反码=它原码符号位不变,其他位取反(0->1,1->0)
4.负数的补码=它的反码+1
5.0的反码、补码、都是0
6.php没有无符号数,就是说php中的都是有符号的
7.在计算机运算的时候都是以补码的方式来运行的

1 如:
2 以下实例都以4个字节举例说明
3 1 ---->原码  00000000 00000000 00000000 00000001
4 1 ---->反码  00000000 00000000 00000000 00000001
5 1 ---->补码  00000000 00000000 00000000 00000001
6
7 -1 --->原码  10000000 00000000 00000000 00000001
8 -1 --->反码  11111111 11111111 11111111 11111110    //符号位不变,其他位取反
9 -1 --->补码  11111111 11111111 11111111 11111111    //等于反码+1
 1 求~2的结果
 2 2 --->原码   00000000 00000000 00000000 00000010   //正数的原码、反码、补码都一样,所以可以直接按位运算
 3 2的补码取反
 4 00000000 00000000 00000000 00000010 ===> 11111111 11111111 11111111 11111101  //取反后变为负数,再按照负数求反码的规则得到反码
 5 取反后结果还是补码,再求反码
 6 11111111 11111111 11111111 11111101 ===> 11111111 11111111 11111111 11111100  //负数的反码=它的补码-1
 7 再根据反码求原码
 8 11111111 11111111 11111111 11111100 ===> 10000000 00000000 00000000 00000011 //负数符号位不变,0变1,1变0
 9 10000000 00000000 00000000 00000011 ===> -3
10 所以~2 = -3
 1 求~-5的结果
 2 -5 --->原码 10000000 00000000 00000000 00000101
 3 根据原码得到反码
 4 -5的原码取反 --->11111111 11111111 11111111 11111010   //符号位不变(0->1,1->0)
 5 根据反码得到补码
 6 -5的补码 ---> 11111111 11111111 11111111 11111011   //负数的补码=反码+1
 7 再将补码取反
 8 11111111 11111111 11111111 11111011 ===> 00000000 00000000 00000000 00000100  //计算机底层运算都是在补码的基础上计算的,所以先得到补码再逐位取反
 9 00000000 00000000 00000000 00000100 是正数,它的反码、原码和补码一样
10 00000000 00000000 00000000 00000100 ===>4
11 所以~-5 = 4
时间: 2024-11-05 12:07:14

二进制的原码、反码、补码及相关计算的相关文章

二进制的原码反码补码

原码是什么? 原码就是早期用来表示数字的一种方式: 一个正数,转换为二进制位就是这个正数的原码.负数的绝对值转换成二进制位然后在高位补1就是这个负数的原码 举例说明: int类型的 3 的原码是 11B(B表示二进制位), 在32位机器上占四个字节,那么高位补零就得: 00000000 00000000 00000000 00000011 int类型的 -3 的绝对值的二进制位就是上面的 11B 展开后高位补零就得: 10000000 00000000 00000000 00000011 但是原

二进制中的原码反码补码

二进制中的原码.反码.补码 1. 原码 原码就是符号位加上真值的绝对值, 即用第一位表示符号, 其余位表示值. 比如如果是8位二进制: [+1]原 = 0000 0001 [-1]原 = 1000 0001 第一位是符号位. 因为第一位是符号位, 所以8位二进制数的取值范围就是: [1111 1111 , 0111 1111] 即 [-127 , 127] 原码是人脑最容易理解和计算的表示方式. 2. 反码 反码的表示方法是: 正数的反码是其本身 负数的反码是在其原码的基础上, 符号位不变,其余

原码, 反码, 补码 详解

本篇文章讲解了计算机的原码, 反码和补码. 并且进行了深入探求了为何要使用反码和补码, 以及更进一步的论证了为何可以用反码, 补码的加法计算原码的减法. 论证部分如有不对的地方请各位牛人帮忙指正! 希望本文对大家学习计算机基础有所帮助! 一. 机器数和真值 在学习原码, 反码和补码之前, 需要先了解机器数和真值的概念. 1.机器数 一个数在计算机中的二进制表示形式,  叫做这个数的机器数.机器数是带符号的,在计算机用一个数的最高位存放符号, 正数为0, 负数为1. 比如,十进制中的数 +3 ,计

[转]原码, 反码, 补码 详解 很全

本篇文章讲解了计算机的原码, 反码和补码. 并且进行了深入探求了为何要使用反码和补码, 以及更进一步的论证了为何可以用反码, 补码的加法计算原码的减法. 论证部分如有不对的地方请各位牛人帮忙指正! 希望本文对大家学习计算机基础有所帮助! 一. 机器数和真值 在学习原码, 反码和补码之前, 需要先了解机器数和真值的概念. 1.机器数 一个数在计算机中的二进制表示形式,  叫做这个数的机器数.机器数是带符号的,在计算机用一个数的最高位存放符号, 正数为0, 负数为1. 比如,十进制中的数 +3 ,计

关于原码, 反码, 补码的复习

原本大一时考试90+的组成原理,隔了太长时间没使用,概念也慢慢模糊了,由于最近考试的基础知识有可能用到,于是,在网上找些资料,整理成这个文章,方便以后某天回来看看,好记性真不如烂笔头. 一. 机器数和真值 在学习原码, 反码和补码之前, 需要先了解机器数和真值的概念. 1.机器数 一个数在计算机中的二进制表示形式,  叫做这个数的机器数.机器数是带符号的,在计算机用一个数的最高位存放符号, 正数为0, 负数为1. 比如,十进制中的数 +3 ,计算机字长为8位,转换成二进制就是00000011.如

[转载]原码, 反码, 补码 详解

本篇文章讲解了计算机的原码, 反码和补码. 并且进行了深入探求了为何要使用反码和补码, 以及更进一步的论证了为何可以用反码, 补码的加法计算原码的减法. 论证部分如有不对的地方请各位牛人帮忙指正! 希望本文对大家学习计算机基础有所帮助! 一. 机器数和真值 在学习原码, 反码和补码之前, 需要先了解机器数和真值的概念. 1.机器数 一个数在计算机中的二进制表示形式,  叫做这个数的机器数.机器数是带符号的,在计算机用一个数的最高位存放符号, 正数为0, 负数为1. 比如,十进制中的数 +3 ,计

原码,反码,补码详解及 Java中>>和>>>的区别

前两天分析 HashMap 的 hash 算法的时候,遇见了 >> 和 >>> 这两个符号,当时查了下资料,在脑子中过了一下.今天又碰到了,没想到竟然忘了  0-0........ 我这记忆力哎,不说了.只好做个笔记,提醒自己,遇到啥不会的最好记下来,好记性不如烂博客啊~ 既然涉及到位运算,我们追本索源,就先从最基础的原码,补码和反码学起.搜了一下这方面的资料,发现一篇专门介绍这方面的文章,写的很是透彻,便直接引用过来了,原文地址是:http://www.cnblogs.co

[转] 原码, 反码, 补码 详解

点击阅读原文 作者:张子秋出处:http://www.cnblogs.com/zhangziqiu/ 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利. 本篇文章讲解了计算机的原码, 反码和补码. 并且进行了深入探求了为何要使用反码和补码, 以及更进一步的论证了为何可以用反码, 补码的加法计算原码的减法. 论证部分如有不对的地方请各位牛人帮忙指正! 希望本文对大家学习计算机基础有所帮助! 一. 机器数和真值 在学习

原码, 反码, 补码 详解(转)

http://www.cnblogs.com/zhangziqiu/archive/2011/03/30/ComputerCode.html 一. 机器数和真值 在学习原码, 反码和补码之前, 需要先了解机器数和真值的概念. 1.机器数 一个数在计算机中的二进制表示形式,  叫做这个数的机器数.机器数是带符号的,在计算机用一个数的最高位存放符号, 正数为0, 负数为1. 比如,十进制中的数 +3 ,计算机字长为8位,转换成二进制就是00000011.如果是 -3 ,就是 10000011 . 那

Java基础——原码, 反码, 补码 详解

上一篇提到了原码.反码和补码(见 http://www.linuxidc.com/Linux/2015-02/113862.htm),可是自己又捋了半天,有点懂了的样子,可是又不能清晰的表达.暂且记住以下两点吧: 正数的反码和补码都与原码一样: 负数的反码.补码与原码不同,负数的反码:原码中除去符号位,其他的数值位取反,0变1,1变0.负数的补码:其反码+1. 做个小Demo,分别写出7和-7的原码.反码.补码.(其中第一位是符号位,0表示正数,1表示负数) Demo 7 -7 原码 00000