`
xinklabi
  • 浏览: 1587010 次
  • 性别: Icon_minigender_1
  • 来自: 吉林
文章分类
社区版块
存档分类
最新评论

原码,补码,反码(针对byte(128) = -128的问题)

阅读更多

int a = 128;

byte b = (byte)a;

那么b = -128,为什么?

第一种理解:

byte的表示范围是-128到+127,128的二进制表示是0000000010000000,若将其强制转换为byte型,则只留下10000000,即-128 。

譬如byte=137,明显超出了byte所能表示的范围;所以取其二进制表示:10001001
首先最高位表示符号位,所以输出结果应该是负数,将其取反变为01110110,加1变为01110111,再将其转化为十进制输出:-119。

第二种理解:

byte可以表示 -128~127之间共256个数,当强制转换一个大于的数a相应的结果为a-256;当强制转换一个小于-128的数b相应结果为b+256

 

 

假设有一 int 类型的数,值为5,那么,我们知道它在计算机中表示为:  00000000 00000000 00000000 00000101  5转换成二制是101,不过int类型的数占用4字节(32位),所以前面填了一堆0。  现在想知道 ...

假设有一 int 类型的数,值为5,那么,我们知道它在计算机中表示为:
  00000000 00000000 00000000 00000101
  5转换成二制是101,不过int类型的数占用4字节(32位),所以前面填了一堆0。
  现在想知道,-5在计算机中如何表示?
  在计算机中,负数以其正值的补码形式表达。
  什么叫补码呢?这得从原码,反码说起。
  
  原码:一个整数,按照绝对值大小转换成的二进制数,称为原码。
  比如 00000000 00000000 00000000 00000101 是 5的 原码。
  反码:将二进制数按位取反,所得的新二进制数称为原二进制数的反码。
  取反操作指:原为1,得0;原为0,得1。(1变0; 0变1)
  比如:将00000000 00000000 00000000 00000101每一位取反,得11111111 11111111 11111111 11111010。
  称:11111111 11111111 11111111 11111010 是 00000000 00000000 00000000 00000101 的反码。
  反码是相互的,所以也可称:
  11111111 11111111 11111111 11111010 和 00000000 00000000 00000000 00000101 互为反码。
  补码:反码加1称为补码。
  也就是说,要得到一个数的补码,先得到反码,然后将反码加上1,所得数称为补码。
  比如:00000000 00000000 00000000 00000101 的反码是:11111111 11111111 11111111 11111010。
  那么,补码为:
  11111111 11111111 11111111 11111010 1 = 11111111 11111111 11111111 11111011
  所以,-5 在计算机中表达为:11111111 11111111 11111111 11111011。转换为十六进制:0xFFFFFFFB。
  
  再举一例,我们来看整数-1在计算机中如何表示。
  假设这也是一个int类型,那么:
  1、先取1的原码:00000000 00000000 00000000 00000001
  2、得反码: 11111111 11111111 11111111 11111110
  3、得补码: 11111111 11111111 11111111 11111111
  
  正数的原码,补码,反码都相同,都等于它本身
  负数的补码是:符号位为1,其余各位求反,末位加1
  反码是:符号位为1,其余各位求反,但末位不加1
  也就是说,反码末位加上1就是补码
  
  1100110011 原
  1011001100 反 除符号位,按位取反
  1011001101 补 除符号位,按位取反再加1
  
  正数的原反补是一样的
  在计算机中,数据是以补码的形式存储的:
  在n位的机器数中,最高位为符号位,该位为零表示为正,为1表示为负;
  其余n-1位为数值位,各位的值可为0或1。
  
  当真值为正时:原码、反码、补码数值位完全相同;
  当真值为负时: 原码的数值位保持原样,
  反码的数值位是原码数值位的各位取反,
  补码则是反码的最低位加一。
  注意符号位不变。
  如:若机器数是16位:
  十进制数 17 的原码、反码与补码均为: 0000000000010001
  十进制数-17 的原码、反码与补码分别为:1000000000010001、1111111111101110、1111111111101111

 

本文来自CSDN博客,转载请标明出处:http://blog.csdn.net/shawnsoft/archive/2009/12/16/5010139.aspx

分享到:
评论

相关推荐

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

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

    数字的原码、反码和补码

    注意:(-128) 没有相对应的原码和反码,(-128) = (10000000)。 补码的加减运算如下:(1)10 - (1)10 = (1)10 + (-1)10 = (0)10(00000001)补 + (11111111)补 = (00000000)补 = (0) 正确(1)10 - (2)10 = (1)10 +...

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

    注意,8位反码的范围是-127(11110001B)到+127(01111111B),但-128(10000000B)是一个特殊值,其反码与原码相同,因为它是通过在原码基础上逐位取反得到的,而不能简单地理解为-127加1。 3. **补码**: 补码是...

    计算机原理原码、反码、补码.docx

    计算机原理原码、反码、补码 计算机原理中,整数的表示方式有三种:原码、反码和补码。这些概念都是为了解决整数在计算机中的表示和存储问题。 首先,让我们来了解一下整数在计算机中的表示范围。一个字节的整数...

    一些原码,反码,补码的笔记

    需要注意的是,由于加1,负数的补码比其原码多一个数值,即-128,这个数没有原码和反码。而正数的原码、反码和补码都是相同的。 在编程中,尤其是在Java、C++等语言中,强制类型转换可能会导致数据溢出。例如,将一...

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

    在8位系统中,-128的补码表示为10000000,而其原码表示为11111111取反后加1,即10000000。 在进行位运算时,理解原码、反码和补码的转换规则非常关键,因为它们直接影响计算结果。例如,位左移、位右移等操作在正...

    补充知识点 原码补码PPT学习教案.pptx

    但特别的是,当最高位为1时,补码也可以表示-128(10000000)。这是因为补码系统允许我们进行减法操作而不必额外处理溢出情况。 总结来说,这个PPT学习教案详细介绍了二进制、八进制和十六进制之间的转换方法,以及...

    Java 补码详细内容解析

    - **`byte`**:8 位补码表示,范围为 -128 至 127。 - **`short`**:16 位补码表示,范围为 -32768 至 32767。 - **`int`**:32 位补码表示,范围为 -2^31 至 2^31-1。 - **`long`**:64 位补码表示,范围为 -2^63 ...

    java中原码、反码与补码的问题分析

    在Java编程语言中,数值类型的数据在计算机内部是以二进制形式存储的,这就涉及到原码、反码和补码的概念。这些编码方式主要用于表示有符号整数,尤其是负数的表示。 1. 原码 原码是最直接的表示方式,其中最高位...

    【IT十八掌徐培成】Java基础第02天-02.字节-负数表示-补码-128计算.zip

    以8位为例,正数的补码就是它自身的原码(即直接的二进制表示),而负数的补码是它的反码(所有位取反)加1。例如,-1的8位补码是11111111,因为它的原码(00000001)取反得到11111110,再加上1得到11111111。 当...

    java byte相互转换详解左右位移

    在Java中,byte是一个8位的有符号整型数据,它的取值范围是-128到127。int是一个32位的有符号整型数据,取值范围是-2,147,483,648到2,147,483,647。由于byte与int的数据位数不同,转换时需要进行特定的处理。 **...

    Java基础50题2023新版

    本资源摘要信息涵盖了Java基础50题2023新版的知识点,涵盖了基础概念、环境变量配置、命令行编程、进制转换、原码补码反码、数据类型转换、算术运算符、浮点数、位运算符、表达式、读程序题、标识符命令规范、键盘...

    计算机组成原理测试测试

    - **补码**:正数的补码与其原码相同,负数的补码是在其反码的基础上,最低位加1。 - 示例: - \((-35)\) 的二进制表示为 \((-100011)_2\)。 - 原码:\(1100011\) - 反码:\(1011100\) - 补码:\(1011101\) -...

    实验报告2-编码转换-学号-姓名.pdf

    在主循环中,程序会根据输入的整数打印其真值、原码(对于-128无效)、反码和补码。 在学习这个实验报告时,学生需要理解以下几个关键概念: - ASCII码:一种字符编码标准,包含128个不同的字符,每个字符对应一个7...

    微机原理:xt CH1绪论.ppt

    - 8位二进制补码能表示的整数范围是-128(10000000B)到+127(01111111B),因此答案是D. -128~+127。 9. 数值计算: - 8位二进制补码由5个1和3个0组成,最大值为11111000B,对应-8;最小值是11111001B,对应-121...

    位运算课件(java学习位运算课件)

    而补码则是用来解决减法问题的,它在原码的基础上对负数的反码加1。补码让减法运算可以通过加法实现,例如,-7的补码是11111001,这是因为-7的反码加1得到它。补码表示的+0和-0是不同的,+0的补码为00000000,而-0的...

    计算机组成原理考试,自检

    原码、反码、补码 - **原码**: 数的原码表示在机器中用符号位的0和1表示数的正负号,而其余表示其数本身。 - **反码**: 对于正数,反码与原码相同;对于负数,反码与原码的符号位不变,数值各位取反。 - **补码**: ...

    云南省计算机一级考试题库三.pdf

    - 对于正数而言,其原码、反码和补码是相同的。 - **正确答案:** 对 26. **负数的原码与补码转换** - 负数的原码的反码的反码仍然是原码本身。 - **正确答案:** 对 27. **正负数的原码与补码转换** - 无论...

Global site tag (gtag.js) - Google Analytics