本文主要是介绍千峰Java教程:010. 进制与转换,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
计算机通常有:十进制、二进制、八进制、十六进制
十进制:
人类算术采用十进制,可能跟人类有十个手指有关。亚里士多德称人类普遍使用十进制,只不过是绝大多数人生来就有10根手指这样一个解剖学事实结果。如:10D、150D、1050D…
二进制:
计算机中的数据都以二进制数字保存。二进制:逢二进一。只有0、1两个值。
如:10D ==1010B
这是计算机中信息的存储单位。
位(Bit):表示一个二进制数码0或1,是计算机存储处理信息的最基本单位。字节(Byte):一个字节由8个位组成。他表示作为一个完整处理单位的8个二进制码。
八进制:
基数为八。
Java中八进制数要以0开头。如:0123
八进制转换成二进制:只需将每个八进制数据替换为相对应的二进制位即可。
现在计算机很少用八进制了。
二进制 | 八进制 |
000 | 0 |
001 | 1 |
010 | 2 |
011 | 3 |
100 | 4 |
101 | 5 |
110 | 6 |
111 | 7 |
十六进制:
二进制表示法太冗长,所以在程序中一般喜欢用十六进制。
十六进制:基数为十六,逢十六斤一。他用abcdef分别表示表示10、11、12、13、14、15。
Java中十六进制数据要以0x或0X开头,如:0x23D。
十六进制转换成二进制只需将每个十六进制数字替换为相对应的四个二进制位即可。
二进制 | 十六进制 |
0000 | 0 |
0001 | 1 |
0010 | 2 |
0011 | 3 |
0100 | 4 |
0101 | 5 |
0110 | 6 |
0111 | 7 |
1000 | 8 |
1001 | 9 |
1010 | a |
1011 | b |
1100 | c |
1101 | d |
1110 | e |
1111 | f |
以上abcdef可大写
补码:
事实上,计算机内的二进制数值是以补码形式表示的。
补码:正数的补码和其原码是相同的,负数的补码是负数的绝对值,先按位取反再加1。
由此可知,二进制补码数值的最高位(最左位)为符号位:该位为0,表示数值为正数,为1表示数值为负数。
十进制 | 二进制 |
10 | 00000000 00000000 00000000 00000001 |
-10 | 11111111 11111111 11111111 11110110 |
主要原因:使用补码,可以将符号位和其他位统一处理;同时,减法也可以按加法来处理。另外,两个用补码表示的数相加时,如果最高位(符号位)有进位,则进位被舍弃。
二进制数转换为十进制数:
按权相加:把二进制数首先写成加权系数展开式,然后按十进制加法规则求和。
例:原码:1011.01 =
=8 + 0 + 2 + 1 + 0 + 0.25
=11.25
十进制数转换成二进制数:
整数部分:”除二取余,逆序排列“法
小数部分:”乘二取整,顺序排列“法
这篇关于千峰Java教程:010. 进制与转换的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!