正数的原码,反码 ,补码都是相同的,
负数的反码是在原码的基础上, 符号位不变, 数值位取反 ;
负数的补码 , 是在反码的末尾+1
计算机底层在做运算的时候,都是使用的 补码 进行
什么是进制
- 进制:就是进位制,是人们规定的一种进位方法。 对于任何一种进制--X进制,就表示某一位置上的数运算时是逢X进一位。二进制就是逢二进一,八进制是逢八进一,十进制是逢十进一,十六进制是逢十六进一。
- 例如一周有七天,七进制,一年有十二个月,十二进制
- B:十进制的由来
- 十进制的由来是因为人类有十个手指
- C:二进制的由来
- 其实二进制来源与中国,请看史料记载
- 18世纪德国数理哲学大师莱布尼兹从他的传教士朋友鲍威特寄给他的拉丁文译本《易经》中,读到了八卦的组成结构,惊奇地发现其基本素数(0)(1),即《易经》的阴爻yao- -和__阳爻,其进位制就是二进制,并认为这是世界上数学进制中最先进的。20世纪被称作第三次科技革命的重要标志之一的计算机的发明与应用,其运算模式正是二进制。它不但证明了莱布尼兹的原理是正确的,同时也证明了《易经》数理学是很了不起的。
- D:八进制的由来
- 任何数据在计算机中都是以二进制的形式存在的。二进制早期由电信号开关演变而来。一个整数在内存中一样也是二进制的,但是使用一大串的1或者0组成的数值进行使用很麻烦。
- 所以就想把一大串缩短点,将二进制中的三位用一位表示。这三位可以取到的最大值就是7.超过7就进位了,这就是八进制。
- E:十六进制的由来
- 但是对于过长的二进制变成八进制还是较长,所以出现的用4个二进制位表示一位的情况,四个二进制位最大是15,这就是十六进制。
- F:不同进制表现同一个数据的形式特点
- 进制越大,表现形式越短
不同进制数据的表现形式
- A:二进制的数据表现形式
- 由0,1组成。以0b(b可以大写也可以小写)开头(JDK1.7版本可以表示二进制了)
- B:八进制的数据表现形式
- 由0,1,…7组成。以0开头
- C:十进制的数据表现形式
- 由0,1,…9组成。整数默认是十进制的
- D:十六进制的数据表现形式
- 由0,1,…9,a,b,c,d,e,f(大小写均可)。以0x开头
- E:案例演示
- 输出不同进制表现100的数据。
- 0b100
- 0100
- 100
- 0x100
任意进制到十进制的转换图解
任意进制到十进制的转换原理
系数:就是每一位上的数据。
基数:X进制,基数就是X。
权:在右边,从0开始编号,对应位上的编号即为该位的权。
结果:把系数*基数的权次幂相加即可。
十进制到任意进制的转换图解
除积倒取余
8421码及特点
8421码是中国大陆的叫法,8421码是BCD代码中最常用的一种。在这种编码方式中每一位二值代码的1都是代表一个固定数值,把每一位的1代表的十进制数加起来,得到的结果就是它所代表的十进制数码。
通过8421码的方式进行二进制和十进制的相互转换
二进制到八进制的简易方式
二进制到十六进制的简易方式
* 不同进制数据的表现形式
* 二进制 由 0 , 1 组成 ; 以 0b 开始
* 八进制 由 0, ..7组成 ; 以 0 开始
* 十进制 由 0,...9组成 ; 整数默认就是十进制
* 十六进制 由 0,...9 a , b , c , d , e ,f 组成 , 以 0x 开始
* 有符号数据表示法:
* 原码
* 反码
* 补码