有道是:学而时习之、又有言:温故而知新,可以为师矣。我想我可以在这些基础当中,领悟更多在工作中忽略的知识。
1byte = 8bit
1k = 1024bit
1M = 1024k
1G = 1024M
1T = 1024G
接下来使用代码打印
二进制0b100
八进制0100
十进制100
十六进制0x100
class Test()
{
public static void main(String[] args)
{
System.out.println(0b100);
System.out.println(0100);
System.out.println(100);
System.out.println(0x100);
}
}
输出结果为:
那么JAVA在编译的时候是如何转换的呢?
十进制>>十进制的转换:
例如:12345 = 10000 + 2000 + 300 + 40 + 5
= 1 * 10 ^ 4 + 2 * 10 ^ 3 + 3 * 10 ^ 2 + 4 * 10 ^ 1 + 5 * 10 ^ 0
其中包含了【系数、基数、次幂】
系数:每一位上的数字
基数:进制,这里是十进制,因此基数为10
次幂:从右向左的次方数,从0开始。
二进制>>十进制的转换:
0b100= 1 * 2 ^ 2 + 0 * 2 ^1 + 0 * 2 ^ 0 = 4
八进制>>十进制的转换:
0100 = 1 * 8 ^ 2 + 0 * 8 ^1 + 0 * 8 ^ 0 = 64
十六进制>>十进制的转换:
0x100 = 1 * 16 ^ 2 + 0 * 16 ^ 1 + 0 * 16 ^ 0 = 256
由以上可得出公式:
结果 = 系数 * 基数 ^ 次幂 。
算一个数的十进制就应该是 系数 乘以 基数 ^次幂相加的结果。
这样,只要记住这个公式,无论多少进制,都可以轻松的转换。
十进制>>任意进制的转换:
例如:12345 ![这里写图片描述](https://imgconvert.csdnimg.cn/aHR0cDovL2ltZy5ibG9nLmNzZG4ubmV0LzIwMTcwNDE4MjE1MjA0OTM1?x-oss-process=image/format,png) 神似而形不似也。据上面的的推算可得,十进制转十进制,倒取原数除以十的余数