文章目录
一、基数和进制
说白了就是数值以多少基数来表示,常用的进制分别有二进制、八进制、十进制和十六进制,其中生活中常用的就是“十进制”,如你的年龄、商品金额等等。
这里要说明基数和进制的关联,十进制就是以10为基数的数,逢10进1,或逢10的倍数进位,基数是进位的基准。其它进制也都遵循这个规则,什么进制就以什么为基数,所以说理论上来说什么进制都存在,只是常用不常用而已,甚至压根就不用。
二、常见进制数的表示
对于不是程序员的大多数人来说,基本都只是使用十进制。而对于程序员,不可避免地会使用到二进制、八进制和十六进制,当然也少不了十进制,毕竟十进制对于人们来说是最容易理解和表达的。
举个例子:如果10是十进制数,那么值就是10;如果10是二进制数,那么值就是2;如果10是八进制数,那么值就是8;如果10是十六进制数,那么值是10,只是用a来表达10。
我们以最熟悉的十进制作为切入点,从而了解其它进制的计算和表示范围。十进制中逢十进一,那么一个十进制数中能出现的数字只有0~9组合而成,对于其它进制同理。
二进制只能用0和1来表示,逢2进1,它是计算机使用的语言,因为对于计算机它有电信号,ON可以表示1,OFF可以表示0。可以想象到数据都是由1和0表示,复杂的数据也就只有计算机能读懂了,举个简单例子:今年是2023年,2023这个数用二进制表示为0111 1110 0111,额其实我也是用计算器来算的,这么表达是不是很费神?但对于接近硬件底层的程序而言,二进制确实非常适合的。
八进制只能用0~7来表达,逢8进1;
十六进制只能用0-9和a-f来表达,a表达10,f表达15,字母不区分大小写,逢16进1。
三、不同基数间的转换
(1)二、八和十六进制数向十进制数转换
还是先从十进制数入手,十进制数的每一位都是10的指数幂:
而如果将这个方法用在二进制、八进制和十六进制数上则能将其转换成十进制数:
(2)十进制数向二、八、十六进制数转换
还是先从十进制入手,先举一个“十进制数向十进制数转换”的例子:
那么用这个方法将十进制数除以相应基数,得到商和余数,不断用商除以基数直到商为0,余数倒着读就能得到转换后的进制数值。
(3)八、十六进制数向二进制数转换(或二进制数向八、十六进制数转换)
这个比较简单。八进制数每1位换成3位二进制数,原因是最大的111刚好是7;十六进制数每1为换成4位二进制数,原因是最大的1111刚好是15。
如八进制数77,转换成二进制就是111111(63),习惯表示0011 1111,高位补0补满8位,8位即1个字节;如十六进制数1F,转换成二进制就是0001 1111(31)。
反过来二进制数向八、十六进制数转换,那分别是3位二进制换1位八进制、4位二进制换1位十六进制,就不做演示了。
(4)八进制数向十六进制数转换(或十六进制数向八进制数转换)
八转十六,可以先将八进制转换成二进制,再从二进制转换十六进制,这是最好算的。或者八进制转十进制,再从十进制转十六进制。
十六转八同理。