位运算
PHP 转 GO 菜鸟一枚,建了一个 go 语言微信交流群,欢迎各位大佬加入,加我微信 XU1014129578 拉群,暗号:gogogo
二进制是逢二进位的进位制,0,1是基本算符
现代的电子计算机技术全部采用的是二进制,因为它只使用0,1两个数字符号,非常简单方便,易于用电子方式实现。计算机内部处理的信息,都是采用二进制数字来表示的。二进制数用0和1两个数字及其组合来表示任何数。进位规则是“逢二进一”,数字1在不同的位上代表不同的值,按从右至左的次序,这个值以二倍递增。
在计算机的内部,运行各种运算时,都是以二进制的方式来运行。
源码,反码,补码
对于有符号的而言:
二进制的最高位是符号位:0表示正数,1表示负数
正数:1 =》 [0000 0001]
负数: -1 =》 [1000 0001]
正数的源码,反码,补码都是一样的
负数的反码 = 它的原码符号位不变,其他位数取反(0->1,1->0)
正数:1 => 原码 [0000 0001] 反码[0000 0001] 补码[0000 0001]
负数: -1=> 原码 [1000 0001] 反码[1111 1110] 补码[1111 1111]
负数的补码=它的反码+1
零的的反码,补码都是0
在计算机运算的时候,都是以补码的方式来运算的
位运算符和移位运算符
Golang中3个位运算
分别是 按位与 & ,按位或 | ,按位异或 ^ ,它们的运算规则是:
- 按位与 & :两位全为1,结果为1,否则为0
- 按位或 | :两位有一个为1 结果为1,否则为0
- 按位异或 ^ : 两位一个为0,一个为1,结果为1,否则为0
负数按位异或 ^
Golang中2个移位运算
>>,<<右移和左移,运算规则:
右移运算符 >> :低位溢出,符号位不变,并用符号位补溢出的高位
a := 1 >> 2 => 0000 0001 => 0000 0000 = 0
左移运算符 << :符号位不变,低位补0
b := 1 >> 2 => 0000 0001 => 0000 0100 = 4
本作品采用《CC 协议》,转载必须注明作者和本文链接
推荐文章: