C语言位运算符知识点整理

最近看到一道题,交换两个相同类型的数字a和b,我最开始想到的是定义一个中间变量temp,利用temp=a;a=b;b=temp;来达到交换两个数的目的,但是我发现这种情况容易溢出,不够安全。后来又想起了C语言的异或^位运算符,一个数异或它本身结果为0,所以运用a=a^b;b=a^b;a=a^b;也能实现交换两个数的目。顺便,我整理了一下C语言的位操作运算符的知识点。


位操作运算符分成位逻辑运算符(&,|,~,^)和移位运算符(<<<,>>>)

&(与运算符)功能

1)能将某些二进制位屏蔽掉。整型在计算机内部以补码形式存储。例如,将整数k的低4位置零,保留其他位,则用与运算,高字节与1相与,低字节与0相与。K=0010 1010 0101 0010,k=k&0Xfff0=0010 1010 0101 0000。结论是任何二进制位与0相与置零,与1相与则保持不变。

2)判断一个数据的某一位是否为1.例如判断a(2个字节)的最高位是否为1.则取一个与a同类型的变量test,令test最高位为1,其他位为0.若a&test=1000 0000 0000 0000,则最高位为1,否则为0.结论是一个数x&1结果的二进制的最末一位若为0,则该数必为偶数,为1则必为奇数。

|(按位或运算符)功能

将某个数的某一位上的数置1,其他位保持不变。例如a=10000100,若将a的第七位置1,则就令b=00000010,a=a|b=10000110

^(按位异或运算符)功能

1)交换两个数,不用临时变量。例如交换a和b的值:a=a^b;b=a^b;a=a^b

2)将一个数的某些位实现翻转,即1变成0,0变成1

~(按位非运算符)功能

将内存中的1和0全部取反。注意整数类型有没有符号,若无符号,求反结果就是该数与其上限的差值

<<<(左移运算符)

规则:对<<<左边的运算量的每一位全部左移相应的位数,右边空出的位补0.例如,a<<<2表示各位向左移2位,a的最高位移出两位,空出的低两位补0.   char a=ox21(十进制数33,二进制00100001),a<<<2=10000100=ox84。位运算转换为乘法运算 a<<

>>>(右移运算符)

规则:对于右移低位被移出去舍弃掉,空出的位补0还是补1,分两种情况:1)a没有符号(逻辑右移),高位补0;2)a有符号(算术右移)空出的高位全部以符号位填补,即正数补0,负数补1.位运算运算符转换为取模运算符 a>>>n等价于a%(2^n - 1).位运算转换为除法运算a>>>n等价于a/(2^n)

你可能感兴趣的:(C语言位运算符知识点整理)