`
endual
  • 浏览: 3544461 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

原码,反码,补码

    博客分类:
  • java
 
阅读更多

1.计算机中任何东西都用0,1两个数表示

2.计算机中0表示正,1表示负

3.计算机中有原码,反码,补码都是由0,1构成的,并且计算机保存的是补码

4.我们最熟悉的是原码,就是我们说的二进制

 

下图是原码,补码之间的关系

 

位运算的


 

 

以下是java位操作符的小总结,具体如下:

二进制负数以它正值的补码形式表达

补码:反码+1等于补码
比如:System.out.println(Integer.toBinaryString(-5));
打印:1111 1111 1111 1111 1111 1111 1111 1011  不用想了肯定是32位  (Adam:因为是int类型)
过程是这样的:
一个负数,比如-5,它的二进制在java里面是这样表示
1000 0000 0000 0000 0000 0000 0000 0101  (Adam:负值是在开头1)
它的正值是:
0000 0000 0000 0000 0000 0000 0000 0101  (Adam:正值开头是0)
反码是:
1111 1111 1111 1111 1111 1111 1111 1010   (Adam:这里是正值的反码)
再加上1是:
1111 1111 1111 1111 1111 1111 1111 1011
即得到打印的内容

java ~ 操作符,对每个二进制位的内容求反,即1变成0,0变成1

测试负数:
int a = -5;//101;
System.out.println(~a);
打印:4
过程是这样的,首先表示出来这个负数
1111 1111 1111 1111 1111 1111 1111 1011(上面已经提到为什么这样表示)
各位取反得到
0000 0000 0000 0000 0000 0000 0000 0100
转为10进制得到4

测试正数:
int a = 5;//101;
System.out.println(~a);
打印:-6
首先表示出来这个正数:
0000 0000 0000 0000 0000 0000 0000 0101
各位取反得到:
1111 1111 1111 1111 1111 1111 1111 1010
这个代表的就是-6了,至于为什么看最上面

java & 操作符,对应的二进制位进行与操作,两个都为1才为1,其他情况均为0
测试:
System.out.println(5&6);
打印:4
过程:
5表示成:0000 0000 0000 0000 0000 0000 0000 0101
6表示成:0000 0000 0000 0000 0000 0000 0000 0110
进行 & :0000 0000 0000 0000 0000 0000 0000 0100
得到:4

java | 操作符,对应的二进制位进行或操作,两个都为0才为0,其他情况均为1
测试:
System.out.println(5|6);
打印:7
过程:
5表示成:0000 0000 0000 0000 0000 0000 0000 0101
6表示成:0000 0000 0000 0000 0000 0000 0000 0110
进行 | :0000 0000 0000 0000 0000 0000 0000 0111
得到:7

java ^ 操作符 当对应二进制位值相同,该位为0 否则为1
测试:
System.out.println(5^6);
打印:3
过程:
5表示成:0000 0000 0000 0000 0000 0000 0000 0101
6表示成:0000 0000 0000 0000 0000 0000 0000 0110
进行 ^ :0000 0000 0000 0000 0000 0000 0000 0011
得到:3

java << 操作符,左边移动,右面填充0
测试:
System.out.println(5<<1);
打印:10
5表示成:0000 0000 0000 0000 0000 0000 0000 0101
进行 <<1 操作:0000 0000 0000 0000 0000 0000 0000 1010

java >> 操作符,左边移动,右面填充0
测试:
System.out.println(5>>>1);
打印:2
5表示成:0000 0000 0000 0000 0000 0000 0000 0101
进行 >>>1 操作:0000 0000 0000 0000 0000 0000 0000 0010

左移动一位相当乘以2 右移动一位相当处以2

 

移位运算

 


 

  • 大小: 87.9 KB
  • 大小: 66.3 KB
  • 大小: 65.2 KB
分享到:
评论

相关推荐

    原码反码补码讲课.pptx

    原码反码补码讲课 计算机中的数值表示是计算机基础知识的重要组成部分。在计算机中,数值可以分为整数和实数两大类。整数又可以分为无符号整数和带符号整数。无符号整数是指不带符号的整数,而带符号整数则是带有...

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

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

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

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

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

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

    二进制原码反码补码.docx

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

    原码反码补码说课.pptx

    "原码反码补码说课.pptx" 本资源是关于计算机组成原理的教学课件,主要讲解了原码、反码和补码的概念、计算方法和表示范围。该课件旨在培养学生实事求是的学风、耐心细致的工作作风和严谨的工作态度。 一、知识...

    原码反码补码图解.

    原码反码补码图解.原码反码补码图解.原码反码补码图解.

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

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

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

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

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

    在计算机科学中,原码、反码和补码是用于表示二进制数值,特别是负数的三种方式。本文将详细讲解这三种编码方式,并通过C#编程语言演示如何进行三码之间的转换。 1. 原码(Direct Code): 原码是最直观的二进制...

    学习电脑信息原码反码补码详细解析

    "学习电脑信息原码反码补码详细解析" 本文详细介绍了原码、反码和补码的概念、计算方法和应用场景。在学习原码、反码和补码之前,需要了解机器数和真值的概念。机器数是指一个数在计算机中的二进制表示形式,带符号...

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

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

    数字的原码、反码和补码

    负数的补码就是对反码加一,而正数不变,正数的原码反码补码是一样的。在补码中用(-128)代替了(-0),所以补码的表示范围为:(-128~0~127),共 256 个。注意:(-128) 没有相对应的原码和反码,(-128) = ...

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

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

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

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

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

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

    电脑计算8位原码反码补码表

    对于-127,它的原码和反码都是1111 1111,补码是1000 0000,而这个特殊的值1000 0000也表示-128,因为-128的补码与+0的补码相同,这是一种规定,使得补码系统可以有256种不同的状态。 在8位二进制的补码表示中,...

    JAVA基础补充(0)-原码反码补码.doc

    本篇将详细解释整数在计算机中的表示方式,尤其是原码、反码和补码的概念。 首先,计算机内部无法直接表示正负符号,因此采用了二进制编码来区分正负。最高位被指定为符号位,其中0代表正数,1代表负数。这种表示...

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

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

    原码反码补码的定义PPT学习教案.pptx

    原码、反码和补码是三种不同的二进制表示方法,主要用于表示有符号整数,尤其是在进行算术运算时。 **原码**是直接用最高位作为符号位来表示数字的正负,0代表正,1代表负。例如,二进制的`0110`表示十进制的6,而`...

Global site tag (gtag.js) - Google Analytics