*原码,反码,补码必须满8位,不足在前填0: 1,原码:用符号位和数值位表示一个带符号的数 +  -> 0                 -   -> 1     表示数的范围-127~+127 例如:[+10011]原=00010011    [-10011]原=10010011     [+0]原=00000000       [-0]原=10000000 2,反码:正数的反码与原码相同,负数的反码是对该数的原码除符号位各位取反 例如:[+10011]反=00010011  [-1001…
以2字节为例来说: 对于无符号的数值(原码反码及补码都一样),最大值为1111  1111  1111  1111=65535 最小值为0000  0000  0000  0000=0 对于有符号的来说较为复杂: 二进制原码最大为0111  1111  1111  1111=215-1=32767 二进制原码最小为1111  1111  1111  1111=-(215-1)=-32767正0和负0:0000000000000000=1000000000000000=0所以,二进制原码表示时,范…
/** * 二进制 binary 如: 1010 * 八进制 octal 如: 070 * 十六进制 hexadecimal 如: 0x7f * * 1Byte = 8bits * 1WORD = 2Bytes = 16bits "字" * 2WORD = 4Bytes = 32bits = 1DWORD "双字" * * 原码, 反码和补码 * 二进制原码中, 第一位代表符号位, 1为负(negative), 0为正(positive) * 正数: 原码 = 反码…
参考: http://www.cnblogs.com/zhangziqiu/archive/2011/03/30/ComputerCode.html http://blog.csdn.net/liushuijinger/article/details/7429197#comments 数值在计算机中是以补码的方式存储的,在探求为何计算机要使用补码之前, 让我们先了解原码, 反码和补码的概念. 对于一个数, 计算机要使用一定的编码方式进行存储. 原码, 反码, 补码是计算机存储一个具体数字的编码方…
原码:用符号位和数值位表示一个带符号数,整数符号->0,负数符号->1,数值一般用二进制形式表示 [+10011]原=00010011    [-10011]原=10010011 反码:正数的反码与原码相同,负数的反码是对该数的原码除符号位外各位取反 [+10011]反=00010011    [-10011]反=11101100 补码:正数的补码与原码相同,负数的补码是对该数的原码除符号位外各位取反,末尾加1 [+10011]补=00010011    [-10011]反=11101101…
本篇文章讲解了计算机的原码, 反码和补码. 并且进行了深入探求了为何要使用反码和补码, 以及更进一步的论证了为何可以用反码, 补码的加法计算原码的减法. 论证部分如有不对的地方请各位牛人帮忙指正! 希望本文对大家学习计算机基础有所帮助! 一. 机器数和真值 在学习原码, 反码和补码之前, 需要先了解机器数和真值的概念. 1.机器数 一个数在计算机中的二进制表示形式,  叫做这个数的机器数.机器数是带符号的,在计算机用一个数的最高位存放符号, 正数为0, 负数为1. 比如,十进制中的数 +3 ,计…
本篇文章讲解了计算机的原码, 反码和补码. 并且进行了深入探求了为何要使用反码和补码, 以及更进一步的论证了为何可以用反码, 补码的加法计算原码的减法. 论证部分如有不对的地方请各位牛人帮忙指正! 希望本文对大家学习计算机基础有所帮助! http://www.cnblogs.com/zhangziqiu/archive/2011/03/30/ComputerCode.html 一. 机器数和真值 在学习原码, 反码和补码之前, 需要先了解机器数和真值的概念. 1.机器数 一个数在计算机中的二进制…
<< 左移 按二进制形式把所有的数字向左移动对应的位数,高位移出(舍弃),低位的空位补零. 格式 需要移位的数字 << 移位的次数 计算过程 1. 按二进制形式把所有的数字向左移动对应的位数,高位移出(舍弃),低位的空位补零 2. 当左移的运算数是int 类型时,每移动1位它的第31位就要被移出并且丢弃: 3. 当左移的运算数是long 类型时,每移动1位它的第63位就要被移出并且丢弃. 4. 当左移的运算数是byte 和short类型时,将自动把这些类型扩大为 int 型. 1…
前两天分析 HashMap 的 hash 算法的时间,会见 >> 和 >>> 这两个符号.然后检查以下信息,我脑子里在某一时刻.今天遇到,我没想到居然忘  0-0........ 我这记忆力哎,不说了.仅仅好做个笔记,提醒自己,遇到啥不会的最好记下来.好记性不如烂博客啊~ 既然涉及到位运算,我们追本索源,就先从最基础的原码,补码和反码学起. 搜了一下这方面的资料,发现一篇专门介绍这方面的文章,写的非常是透彻,便直接引用过来了,原文地址是:http://www.cnblogs.…
原码:就是我们自己看的,以及机器输出给我们看的 补码:机器永远是以补码的形式将数据保存在计算机中 正数: 原码=反码=补码 负数: 反码:原码的符号位不变,其他位取反 ,1变0   0变1 补码:机器存储数据的方式 等于 反码+1 例子: 96(默认int数据类型): 原码:00000000 00000000 00000000 01100000 共32位 补码:00000000 00000000 00000000 01100000 -96: 原码:10000000 00000000 000000…