D 语言 - 按位运算符
D语言支持的按位运算符如下表所示。 假设变量 A 为 60,变量 B 为 13,则 −
运算符 | 描述 | 示例 |
---|---|---|
& | 如果两个操作数中都存在,则二元 AND 运算符会将一位复制到结果中。 | (A & B) 将给出 12,表示 0000 1100。 |
| | 二元或运算符复制一个位(如果任一操作数中存在该位)。 | (A | B) 将给出 61。意味着 0011 1101。 |
^ | 如果在一个操作数中设置了该位,但不是在两个操作数中都设置了该位,则二元异或运算符会复制该位。 | (A ^ B) 将给出 49。意味着 0011 0001 |
~ | 二进制补码运算符是一元的,具有"翻转"位的效果。 | (~A ) 给出 -61。 表示 2 的补码形式的 1100 0011。 |
<< | 二进制左移运算符。 左操作数的值向左移动右操作数指定的位数。 | A << 2 给出 240。意味着 1111 0000 |
>> | 二进制右移运算符。 左操作数的值向右移动右操作数指定的位数。 | A >> 2 给出 15。意味着 0000 1111。 |
示例
尝试以下示例来了解 D 编程语言中可用的所有按位运算符 −
import std.stdio; int main(string[] args) { uint a = 60; /* 60 = 0011 1100 */ uint b = 13; /* 13 = 0000 1101 */ int c = 0; c = a & b; /* 12 = 0000 1100 */ writefln("Line 1 - Value of c is %d\n", c ); c = a | b; /* 61 = 0011 1101 */ writefln("Line 2 - Value of c is %d\n", c ); c = a ^ b; /* 49 = 0011 0001 */ writefln("Line 3 - Value of c is %d\n", c ); c = ~a; /*-61 = 1100 0011 */ writefln("Line 4 - Value of c is %d\n", c ); c = a << 2; /* 240 = 1111 0000 */ writefln("Line 5 - Value of c is %d\n", c ); c = a >> 2; /* 15 = 0000 1111 */ writefln("Line 6 - Value of c is %d\n", c ); return 0; }
当你编译并执行上面的程序时,它会产生以下结果 −
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 -61 Line 5 - Value of c is 240 Line 6 - Value of c is 15
❮ d_programming_operators.html