上次健民欧巴留了这样一个作业:弄清楚反码,补码,原码的定义与区别,在寻仙问道之后,我明白了很多关于反码,补码,原码的东西。
原码,通俗的说就是以二进制的定点数表示;反码,就是正数与原码相同,负数部分与原码的相反;补码,就是正数与原码相同,负数在反码的基础上加1。
比如说:(ziqiu.zhang)
计算机巧妙地把符号位参与运算, 并且将减法变成了加法, 背后蕴含了怎样的数学原理呢?
将钟表想象成是一个1位的12进制数. 如果当前时间是6点, 我希望将时间设置成4点, 需要怎么做呢?我们可以:
1. 往回拨2个小时: 6 - 2 = 4
2. 往前拨10个小时: (6 + 10) mod 12 = 4
3. 往前拨10+12=22个小时: (6+22) mod 12 =4
2,3方法中的mod是指取模操作, 16 mod 12 =4 即用16除以12后的余数是4.
所以钟表往回拨(减法)的结果可以用往前拨(加法)替代!
现在的焦点就落在了如何用一个正数, 来替代一个负数. 上面的例子我们能感觉出来一些端倪, 发现一些规律. 但是数学是严谨的. 不能靠感觉.
有种简单的表达方法:
1. 反码=除符号位按位取反的值。
2. 补码=反码+1
3. 对补码求反加1即得原码;对原码求反加1即得补码。
负数在内存中用其补码表示。所以,对于char型数据,10000000为-128;10000001为-127;11111111为-1。例:1100110011 原 1011001100 反 除符号位,按位取反
1011001101 补 除符号位,按位取反再加1
就这些了,寻觅寻觅,思索思索,没有更深刻的理解了。