C#位运算符

来源:互联网 发布:ipad看tvb软件 编辑:程序博客网 时间:2024/06/16 11:08

位运算符

位运算符作用于位,并逐位执行操作。&、 | 和 ^ 的真值表如下所示:

pqp & qp | qp ^ q00000010111111010011

假设如果 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


小编总结的口诀:

p&q  只要一方为0则为0,同为1时则为1

p|q   只要一方为1则为1,同为0时则为0

p^q  不同为1,相同为0


下表列出了 C# 支持的位运算符。假设变量 A 的值为 60,变量 B 的值为 13,则:

运算符描述实例&如果同时存在于两个操作数中,二进制 AND 运算符复制一位到结果中。(A & B) 将得到 12,即为 0000 1100|如果存在于任一操作数中,二进制 OR 运算符复制一位到结果中。(A | B) 将得到 61,即为 0011 1101^如果存在于其中一个操作数中但不同时存在于两个操作数中,二进制异或运算符复制一位到结果中。(A ^ B) 将得到 49,即为 0011 0001~按位取反运算符是一元运算符,具有"翻转"位效果,即0变成1,1变成0,包括符号位。(~A ) 将得到 -61,即为 1100 0011,一个有符号二进制数的补码形式。<<二进制左移运算符。左操作数的值向左移动右操作数指定的位数。A << 2 将得到 240,即为 1111 0000>>二进制右移运算符。左操作数的值向右移动右操作数指定的位数。A >> 2 将得到 15,即为 0000 1111

实例

请看下面的实例,了解 C# 中所有可用的位运算符:

using System;namespace OperatorsAppl{    class Program    {        static void Main(string[] args)        {            int a = 60;               /* 60 = 0011 1100 */              int b = 13;               /* 13 = 0000 1101 */            int c = 0;                        c = a & b;           /* 12 = 0000 1100 */              Console.WriteLine("Line 1 - c 的值是 {0}", c );             c = a | b;           /* 61 = 0011 1101 */             Console.WriteLine("Line 2 - c 的值是 {0}", c);             c = a ^ b;           /* 49 = 0011 0001 */             Console.WriteLine("Line 3 - c 的值是 {0}", c);             c = ~a;               /*-61 = 1100 0011 */             Console.WriteLine("Line 4 - c 的值是 {0}", c);             c = a << 2;     /* 240 = 1111 0000 */             Console.WriteLine("Line 5 - c 的值是 {0}", c);             c = a >> 2;     /* 15 = 0000 1111 */             Console.WriteLine("Line 6 - c 的值是 {0}", c);            Console.ReadLine();        }    }}

当上面的代码被编译和执行时,它会产生下列结果:

Line 1 - c 的值是 12Line 2 - c 的值是 61Line 3 - c 的值是 49Line 4 - c 的值是 -61Line 5 - c 的值是 240Line 6 - c 的值是 15

原创粉丝点击