非整形的二进制数
在第一章讨论数制的时候,我们只讨论了整形。显然,和十进制一样,其它进制必须也能表示非整形数。在十进制中,在小数点右边的数字关联了10的负乘方值:
不必惊讶,二进制也是以同样的方法表示:
这个办法与第一章中的整形办法相结合就可以用来转换一个一般数值:
将十进制转换成二进制也不是很难。一般来说,需将十进制数分成两块:整数部分和分数部分。使用第一章中的方法来将整数部分转换成二进制。分数部分的转换可以使用下面描述的方法。 考虑一个用a、b、c···标记比特位的二进制分数。这个数用二进制表示为: 0.abcdef... 将此数乘2.新得到的数的二进制表示将是: a.bcdef... 注意,第一个比特位现在在权值为1的位置。用0替换a得到: 0.bcdef... 再乘以2得到: b.cdef... 现在第二个比特位(b)在权值为1的位置。重复这个过程,直到得到了需要的尽可能多的比特位。图6.1展示了一个实例:将0.5625转换成二进制。这种方法当分数部分为0了才停止。
另一个例子,将23.85转换成二进制。将整数部分
转换成二进制是容易的,但是分数部分呢?图6.2展示了这个计算的开始部分。如果你仔细看了这个数值,就会发现一个无限循环。这就意味着0.85是一个无限循环的