C语言中按位或,与,非是怎么用的,怎么运算?

如题所述

位运算符
C提供了六种位运算运算符;这些运算符可能只允许整型操作数,即char、short、int和long,无论signed或者unsigned。
&
按位AND
|
按位OR
^
按位异或
<<
左移
>>
右移
~
求反(一元运算)
按位与操作&通常用于掩去某些位,比如
n
=
n
&
0177;
使得n中除了低7位的各位为0。
按位或操作|用于打开某些位:
x
=
x
|
SET_ON;
使得x的某些SET_ON与相对的位变为1。
按位异或操作^使得当两个操作数的某位不一样时置该位为1,相同时置0。
应该区分位操作符&、|与逻辑操作符&&、||,后者从左到右的评价一个真值。比如,如果x为1、y为2,那么x
&
y为0,而x
&&
y为1。
移位运算符<<和>>将左侧的操作数左移或者右移右操作数给定的数目,右操作数必须非负。因此x
<<
2将x的值向左移动两位,用0填充空位;这相当于乘4。右移一个无符号数会用0进行填充。右移一个带符号数在某些机器上会用符号位进行填充(“算数移位”)而在其他机器上会用0进行填充(“逻辑移位”)。
单目运算符~对一个整数求反;即将每一个1的位变为0,或者相反。比如
x
=
x
&
~077
将x的后六位置0。注意x
&
~077的值取决于字长,因此比如如果假设x是16位数那么就是x
&
0177700。这种简易型式并不会造成额外开销,因为~077是一个常数表达式,可以在编译阶段被计算。
作为一个使用位操作的实例,考虑函数getbits(x,p,n)。它返回以p位置开始的n位x值。我们假设0位在最右边,n和p是正数。例如,getbits(x,4,3)返回右面的4、3、2位。
/*
getbits:
返回从位置p开始的n位
*/
unsigned
getbits(unsigned
x,
int
p,
int
n)
{
return
(x
>>
(p+1-n))
&
~(~0
<<
n);
}
表达式x
>>
(p+1-n)将需要的域移动到字的右侧。~0是全1;将其左移n为并在最右侧填入0;用~使得最右侧n个1成为掩码。
温馨提示:内容为网友见解,仅供参考
第1个回答  推荐于2017-06-25
按位或规则:
1|1=1
1|0=1
0|1=1
0|0=0

按位与规则:
1&1=1
1&0=0
0&1=0
0&0=0

非运算规则:
~1=0
~0=1
对每一个二进制位进行相应的运算。本回答被网友采纳
第2个回答  2006-07-30
你先把所有的操作数换算成二进制,就知道怎么算了,很简单。
第3个回答  2020-02-29
x是有符号整数,所以
~x的值是
-14,
而不是
242
,如果你定义x为无符号整数,就会得到242了。
00001101
右移一位

00000110
右移两位是
00000011
第4个回答  2017-06-25
很有用 比如说 奇偶检验码 就是 按位与 实现的 还有一些 要计算的 判定条件什么的 以后写多了代码就知道了
相似回答