~ 按位非(NOT) b = ~a
&按位与(AND) c = a & b
| 按位或(OR) c = a | b
^ 按位异或(XOR) c = a ^ b
>>右移 b = a >> 2
>>>右移,左边空出的位以0填充 b = a >>> 2
<<左移 b = a << 1
当然同样有 &=,|=,^=,>>=,>>>=,<<=。
有关这些 *** 作的细节可以参看
位运算
前面介绍的各种运算都是以字节作为最基本位进行的。 但在很多系统程序中常要求在位(bit)一级进行运算或处理。C语言提供了位运算的功能, 这使得C语言也能像汇编语言一样用来编写系统程序。
一、位运算符C语言提供了六种位运算符:
& 按位与
| 按位或
^ 按位异或
~ 取反
<< 左移
>> 右移
1. 按位与运算 按位与运算符"&"是双目运算符。其功能是参与运算的两数各对应的二进位相与。只有对应的两个二进位均为1时,结果位才为1 ,否则为0。参与运算的数以补码方式出现。
例如:9&5可写算式如下: 00001001 (9的二进制补码)&00000101 (5的二进制补码) 00000001 (1的二进制补码)可见9&5=1。
按位与运算通常用来对某些位清0或保留某些位。例如把a 的高八位清 0 , 保留低八位, 可作 a&255 运算 ( 255 的二进制数为0000000011111111)。
main(){
int a=9,b=5,c
c=a&b
printf("a=%d\nb=%d\nc=%d\n",a,b,c)
}
2. 按位或运算 按位或运算符“|”是双目运算符。其功能是参与运算的两数各对应的二进位相或。只要对应的二个二进位有一个为1时,结果位就为1。参与运算的两个数均以补码出现。
例如:9|5可写算式如下: 00001001|00000101
00001101 (十进制为13)可见9|5=13
main(){
int a=9,b=5,c
c=a|b
printf("a=%d\nb=%d\nc=%d\n",a,b,c)
}
3. 按位异或运算 按位异或运算符“^”是双目运算符。其功能是参与运算的两数各对应的二进位相异或,当两对应的二进位相异时,结果为1。参与运算数仍以补码出现,例如 9^5可写成算式如下: 00001001^00000101 00001100 (十进制为12)
main(){
int a=9
a=a^15
printf("a=%d\n",a)
}
4. 求反运算 求反运算符~为单目运算符,具有右结合性。 其功能是对参与运算的数的各二进位按位求反。例如~9的运算为: ~(0000000000001001)结果为:1111111111110110
5. 左移运算 左移运算符“<<”是双目运算符。其功能把“<< ”左边的运算数的各二进位全部左移若干位,由“<<”右边的数指定移动的位数,
高位丢弃,低位补0。例如: a<<4 指把a的各二进位向左移动4位。如a=00000011(十进制3),左移4位后为00110000(十进制48)。6. 右移运算 右移运算符“>>”是双目运算符。其功能是把“>> ”左边的运算数的各二进位全部右移若干位,“>>”右边的数指定移动的位数。
例如:设 a=15,a>>2 表示把000001111右移为00000011(十进制3)。 应该说明的是,对于有符号数,在右移时,符号位将随同移动。当为正数时, 最高位补0,而为负数时,符号位为1,最高位是补0或是补1 取决于编译系统的规定。Turbo C和很多系统规定为补1。
第一种:1个LED发光,循环右移。第二种:2个LED发光,循环右移。
第三种:3个LED发光,循环右移。
第四种:4个LED发光,循环右移。
再改成左移,就又有四种。
这就有八种了。
一边移动,一边闪烁;
再改变一下速度;
这能有多少种了?
0变1其它位不变,位或一个该位为1其它位为0的数可得1变0其它位不变,位与一个该位为0其它位为1的数可得
得到等N位为1其它位为0的数,可用1左移N位即得
得到等N位为0其它位为1的数,用前数位反一下即得
演示程序:
#include<stdio.h>
char*int2bin(int ,char* )
int main()
{
int x0,x1,n,flag
char x0b[33]={0}
char x1b[33]={0}
while(1)
{
x0 = x1 = n = flag = -1
printf("输入原始数值 *** 作位(0-31) 和 *** 作方式(1置/0清)\n")
scanf("%d %d %d", &x0, &n, &flag)
if( n<0 || n>31 || flag!=0&&flag!=1 ) break//无效输入将退出
if(flag==1)//置1
{
x1 = x0 | (1<<n)//n位置1
}
else//清0
{
x1 = x0 &~(1<<n)//n位清0
}
printf("处理前十进制:%-10d 二进制:%s\n", x0,int2bin(x0,x0b))
printf("处理后十进制:%-10d 二进制:%s\n\n",x1,int2bin(x1,x1b))
fflush(stdin)
}
return 0
}
char*int2bin(int x,char*out)
{
for(int i=0i<32i++)
out[i] = (x&(1<<(31-i))) ? '1' : '0'
out[32] = '\0'
return out
}
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)