我是一个仅出于乐趣而编写代码的人,并且在学术或专业环境中都没有真正地去研究它,所以像这些按位运算符之类的东西真的让我感到困惑。
我正在阅读一篇有关JavaScript的文章,该文章显然支持按位操作。我一直看到该操作在某些地方提到过,并且我尝试阅读以弄清楚它到底是什么,但是我似乎一点也不了解。那是什么 清楚的例子会很棒!:D
再问几个问题-按位运算的一些实际应用是什么?您什么时候可以使用它们?
由于没有人提出这些有用的主题:
在处理标志时,我经常使用按位运算。例如,如果您要将一系列标志传递给某个操作(例如,File.Open()同时启用了读取模式和写入模式的),则可以将它们作为单个值传递。这是通过在位集中为每个可能的标志分配自己的位来实现的(字节,short,int或long)。例如:
File.Open()
Read: 00000001 Write: 00000010
因此,如果您要通过读写,则可以通过(READ | WRITE),然后将两者合并为
00000011
然后可以在另一端将其解密,例如:
if ((flag & Read) != 0) { //...
哪个检查
00000011 & 00000001
哪个返回
00000001
它不是0,因此该标志确实指定了READ。
您可以使用XOR来切换各个位。我在使用标志指定方向输入(上,下,左,右)时使用了此方法。例如,如果一个精灵正在水平移动,而我希望它转过身:
Up: 00000001 Down: 00000010 Left: 00000100 Right: 00001000 Current: 00000100
我只是简单地将当前值与(LEFT | RIGHT)进行异或,在这种情况下,它将关闭LEFT并打开RIGHT。
移位在某些情况下很有用。
x << y
是相同的
x * 2 y
如果您需要快速乘以2的幂,但是要注意将1位移位到最高位-否则该数将为负,除非它是无符号的。在处理不同大小的数据时,它也很有用。例如,从四个字节读取一个整数:
int val = (A << 24) | (B << 16) | (C << 8) | D;
假设A是最高有效字节,D是最低字节。最终结果为:
A = 01000000 B = 00000101 C = 00101011 D = 11100011 val = 01000000 00000101 00101011 11100011
颜色通常以这种方式存储(最高有效字节被忽略或用作Alpha):
A = 255 = 11111111 R = 21 = 00010101 G = 255 = 11111111 B = 0 = 00000000 Color = 11111111 00010101 11111111 00000000
要再次查找这些值,只需将这些位向右移动,直到其位于底部,然后屏蔽掉其余的高阶位:
Int Alpha = Color >> 24 Int Red = Color >> 16 & 0xFF Int Green = Color >> 8 & 0xFF Int Blue = Color & 0xFF
0xFF与相同11111111。因此,从本质上讲,对于Red,您将这样做:
0xFF
11111111
Color >> 16 = (filled in 00000000 00000000)11111111 00010101 (removed 11111111 00000000) 00000000 00000000 11111111 00010101 & 00000000 00000000 00000000 11111111 = 00000000 00000000 00000000 00010101 (The original value)