我们知道,计算机最底层是使用的是二进制。那么为什么只是二进制而不是十进制或者是其他进制的来作为计算机的底层呢?
这主要的原因由计算机的硬件有关,组成计算机系统的的逻辑电路只有两种状态,(接通和断开),只有两种发生的可能。当我们的计算机受到干扰的时候,任然能清楚的识别出逻辑电路的状态(接通和断开)。所以在具体的系统实现中,二进制的数据表达具有抗干扰能力强的优点。相比之下,十进制设计的状态电路就有十种状态的电路,具体的系统实现会变得非常的负责,在判断中出现错误的可能性几率会大大增大。
二进制的操作:
向左位移一位,就是原来的数字翻倍。二进制右移一位,就是将数字除于二并求整数商。(左移(<<)右移(>>>))
(这里是未考虑数字溢出情况)
所谓数字溢出,就是⼆进制数的位数超过了系统所指定的位数。目前主流的系统都⽀持⾄少32位的整型数字,因此1101010远未
超过32位,所以不会溢出。如果进行左移操作的二进制已经超出了32位,左移后数字就会溢出,需要将溢出的位数去除。
Int32 //等于int, 占4个字节(-2147483648~2147483647)
Int64 //等于long, 占8个字节(-9223372036854775808~9223372036854775807)
逻辑操作:
“或”:参与操作的位数中只要有1,最终结果就是1.
1010(与下对齐)
1001
结果:1011
“与”:参与操作的位数必须全部都是1,才为1,否则为0.
1011
1101
结果 1001
“异或”:参与操作的位数相同,为0,否则为1.
100100
110101
结果 010001