`

二进制 原码 反码 补码

    博客分类:
  • Java
 
阅读更多
只有 有符号 的数据才有 原码 反码 补码 这些个概念

对于有符号的 存储类型来说

1.二进制的最高位是符号位:0表示正数;1表示负数

2.正数的原码、反码、补码都一样

3.负数的反码 = 它的原码符号位不变,其他位取反(0变1,1变0)

4.0的反码、补码都是0

5.java没有无符号数,java中的数都是有符号的

6.计算机存储有符号的整数时,都是用该整数的补码进行存储的



负数 的原码、反码、补码

(1)byte类型的-2 的原码:因为是负数, 所以符号位是1 ,其他位是 -2的绝对值 的非符号位,即 000 0010

                          所以 -2 的原码 = 1(符号位)000 0010

(2)byte类型的-2 的反码:-2的原码= 1000 0010,反码是符号位不变,其他位 取反,所以-2的反码= 1111 1101

(3)byte类型的-2 的补码:-2的反码= 1111 1101 ,补码是反码+1,所以-2的补码= 1111 1110



已知负数的原码,它的补码= 反码+1

已知负数的补码,它的原码= 补码-1 后 取反码



位运算 符 ~ 时,不管 符号位还是非符号位,都要 取反

移位运算符 >> (算术右移):低位溢出,符号位不变,并用符号位补充 溢出的高位

           << (算术左移):符号位不变,低位补0



举例

例1: byte a= 1; byte b= 1; a + b 运算过程是

byte 类型占 1个字节

1 的补码,也就是它的原码: 0000 0001

两个 1 加到一起 就是 0000 0010

这个是补码,它的原码也是 0000 0010,所以 a+b= 2



例2:byte a= 1; byte b= 2; a - b的运算是:

在计算机运算时,它是 这样运算的  1 + (-2)

1 的补码 例1 中已经 有了:0000 0001

-2 的补码是:原码1(符号位)000 0010 --> 反码 1(符号位不变)111 1101(其他位取反)-->补码1111 1110
1+ (-2)后 就是: 1111 1111

这个是补码,转原码 的过程是 减1 再取反 ,结果就是 1000 0001 也就是-1


例3: byte a= -5,; ~ a的运算过程是

-5的补码是: 1111 1011

~运算后,所有的位(包括符号位)都取反,变为 : 0000 0100

这个结果的原码 就是0000 0100 ,所以结果 就是这个 4



例4: byte a= 1; a >> 2 的运算是

1 的补码: 0000 0001

右移两位 ,将最后面的两位 01 移出,就是 0_ _ 0 0000,_ _ 就是空出的 两位,用符号位 0 补充,就变成了 0000 0000, 把它转为原码,还是  0000 0000,所以最好结果就是0

分享到:
评论
1 楼 intresources 2012-02-13  
 

相关推荐

    二进制原码反码补码.docx

    二进制原码反码补码知识点总结 计算机内部采用的是二进制,只有两个数字用于表示数据,即 0 和 1,所以它的进制原则是满 2 进 1。十进制用的是 0、1、2、3……9 十个数字来表示数据,它的原则是满 10 进 1。 二...

    二进制转原码反码补码 C语言源码

    /* *功能实现任意二进制数的原码 反码 补码转换 *仅仅是字符串的操作,没有进行数字操作 *对-0的操作可能有问题 *ssfshine@gmail.com */

    16进制(4位)到二进制原码、反码、补码计算

    16进制(4位)到二进制原码、反码、补码计算

    计算机基础知识:原码反码补码练习(含答案)

    原码、反码和补码是二进制表示正负数的关键概念,它们主要用于无符号整数和有符号整数的表示。以下是对这些知识点的详细解释: 1. **原码**:原码是最直观的二进制表示,其中最高位(称为符号位)为0表示正数,为1...

    二进制-原码-补码-反码.pdf

    "二进制-原码-补码-反码" 在计算机科学中,二进制数是计算机中最基本的表示形式。为了能够正确地表示和处理有符号数和无符号数,计算机科学家们提出了原码、反码和补码三种表示方法。 原码是指在二进制数的最高位...

    原码反码补码PPT学习教案.pptx

    原码反码补码PPT学习教案 原码反码补码是计算机系统中最基本的概念之一,了解原码反码补码的原理和应用对于计算机科学和技术的学习非常重要。本资源摘要信息将对原码反码补码的概念、特点和应用进行详细的介绍。 ...

    原码、反码、补码三码转换(C#)

    这段代码首先将-5转换为二进制原码,然后计算其反码和补码,最后通过反码和补码计算回原码。注意,从反码和补码回溯到原码时,可能会因为溢出而产生额外的符号位处理。 在实际应用中,理解原码、反码和补码的概念...

    二进制原码补码反码.pptx

    二进制原码补码反码.pptx

    二进制原码补码反码.docx

    二进制原码补码反码 二进制原码补码反码是计算机中数字表示的三种方式,它们之间的关系非常重要,深入了解它们可以帮助我们更好地理解计算机的工作原理。 原码 原码是将最高位作为符号位(0表示正,1表示负),...

    进制转换及原码反码补码练习题.doc

    本文档主要涵盖了进制转换及原码反码补码的相关知识点,包括二进制、八进制、十进制、十六进制之间的转换关系,原码、反码、补码的概念和计算方法,以及相关的练习题和解析。 一、进制转换 1.1、二进制转十进制 ...

    vi.zip_16进制补码_Labview 进制_labview 二进制_labview补码_二进制补码

    这个"vi"程序可能包含了一个用户界面,其中包含输入框让用户输入16进制数值,然后通过编程逻辑实现转换和计算功能,最后在显示区域展示二进制原码、反码和补码的结果。用户还可以通过运行这个VI了解和学习不同进制间...

    定点数机器码转换器(原码、反码、补码、移码)

    定点数机器码转换器。十进制输入示例:12345、0.12345、-12345、-0.12345;二进制输入示例:10101、0.10101、-10101、-0.10101,将定点数转换成机器码

    十进制转换二进制(原码)

    十进制转换二进制计算机是采用二...这是一个把十进制数字转换到它的二进制原码的算法,希望能给大家一些启发吧!这个算法我是用VB6写的,其中用到了函数递归调用和函数可选参数(个人感觉功能和C++中的函数重载差不多)。

    进制转换及原码反码补码.docx

    进制转换及原码反码补码 在计算机系统中,数字系统是基础部分,很多计算机科学家和程序员需要熟悉不同的数字系统和它们之间的转换。下面我们将详细介绍进制转换、原码、反码和补码的概念和应用。 一、进制数的表达...

    进制转换+原码反码补码参照.pdf

    进制转换和原码反码补码参照 根据提供的文件信息,本节将详细探讨进制转换和原码反码补码的相关知识点。 6.1 为什么需要八进制和十六进制? 在编程中,我们常用的还是十进制,因为C/C++是高级语言。但是,由于...

    二进制-原码-补码-反码

    ### 二进制-原码-补码-反码 #### 一、基本概念 **二进制**是计算机中最基本的数据表示方式,它只包含两个数字:0 和 1。计算机内部的所有数据处理和存储都是基于二进制来进行的。 在计算机科学中,根据是否携带...

    补码源码反码转换工具,补码反码原码的转换工具,C/C++

    在计算机科学中,二进制表示的数字有三种主要形式:原码、反码和补码,主要用于表示有符号整数。本项目是基于C++的MFC(Microsoft Foundation Classes)框架实现的一个实用工具,旨在帮助用户理解并进行原码、反码和...

    原码,反码,补码详解及原理.docx

    原码、反码和补码是计算机中用来表示有符号整数的重要概念,它们主要用于二进制数的存储和计算,特别是在计算机硬件中简化运算过程。以下是对这些概念的详细解释: 1. **原码**: 原码是最直观的表示方式,直接在...

    php_二进制_原码_反码_补码.docx

    理解二进制的原码、反码、补码是非常重要的。本文将详细介绍二进制的基本概念、原码、反码、补码的关系,以及 PHP 中的位运算符。 一、 二进制的基本概念 在计算机科学中,二进制是一种以 0 和 1 两种数字来表示...

Global site tag (gtag.js) - Google Analytics