Show Example
优质
小牛编辑
127浏览
2023-12-01
按位运算符处理位并执行逐位运算。 &&&(按位AND),|||的真值表 (按位OR),^^^(按位异或)如下 -
p | q | p &&& q | p ||| q | p ^^^ q |
0 | 0 | 0 | 0 | 0 |
0 | 1 | 0 | 1 | 1 |
1 | 1 | 1 | 1 | 0 |
1 | 0 | 0 | 1 | 1 |
假设A = 60; 和B = 13; 现在以二进制格式,他们将如下 -
A = 0011 1100
B = 0000 1101
-----------------A &&& B = 0000 1100
A ||| B = 0011 1101
A ^^^ B = 0011 0001
~~~ A = 1100 0011
F#语言支持的Bitwise运算符如下表所示。 假设变量A保持60,变量B保持13,则 -
操作者 | 描述 | 例 |
---|---|---|
&&& | 如果二进制AND运算符存在于两个操作数中,则它会将结果复制到结果中。 | (A &&& B)将给出12,即0000 1100 |
||| | 二进制OR运算符如果存在于任一操作数中,则复制一位。 | (A ||| B)将给出61,即0011 1101 |
^^^ | 二进制异或运算符如果在一个操作数中设置但不在两个操作数中设置,则复制该位。 | (A ^^^ B)将给出49,即0011 0001 |
~~~ | 二元一元补语运算符是一元的,具有“翻转”位的效果。 | (~~~ A)将给出-61,即2的补码形式的1100 0011。 |
<<< | 二进制左移运算符。 左操作数值向左移动右操作数指定的位数。 | <<< 2将给出240,即1111 0000 |
>>> | 二进制右移运算符。 左操作数值向右移动右操作数指定的位数。 | A >>> 2将给出15,即0000 1111 |
例子 (Example)
let a : int32 = 60 // 60 = 0011 1100
let b : int32 = 13 // 13 = 0000 1101
let mutable c : int32 = 0
c <- a &&& b // 12 = 0000 1100
printfn "Line 1 - Value of c is %d" c
c <- a ||| b // 61 = 0011 1101
printfn "Line 2 - Value of c is %d" c
c <- a ^^^ b // 49 = 0011 0001
printfn "Line 3 - Value of c is %d" c
c <- ~~~a // -61 = 1100 0011
printfn "Line 4 - Value of c is %d" c
c <- a <<< 2 // 240 = 1111 0000
printfn "Line 5 - Value of c is %d" c
c <- a >>> 2 // 15 = 0000 1111
printfn "Line 6 - Value of c is %d" c
编译并执行程序时,它会产生以下输出 -
Line 1 - Value of c is 12
Line 2 - Value of c is 61
Line 3 - Value of c is 49
Line 4 - Value of c is 49
Line 5 - Value of c is 240
Line 6 - Value of c is 15