c语言中a&b什么时候==1
展开全部
只有对应的两个二进位均为1时;a=%d\:9&5可写算式如下。
例如,b=5。其功能是参与运算的两数各对应的二进位相与,a,b。
按位与运算通常用来对某些位清0或保留某些位;
}
if(add&0x80==1)
==
add&0x80永远不可能为1。例如把a
的高八位清
0
;n",c,
保留低八位,
可作
a&255
运算
(
255
的二进制数为0000000011111111);&"。
按位与运算
按位与运算符"。参与运算的数以补码方式出现;nb=%d\:
00001001
(9的二进制补码)&00000101
(5的二进制补码)
00000001
(1的二进制补码)可见9&5=1;nc=%d\,c);
c=a&b&是位与的意思,如果两个数对应的两进制位都为1,结果位才为1
,此位为1;;是双目运算符;
printf("。
0x80的最后一位是0,否则为0。
main(){
int
a=9
例如,b=5。其功能是参与运算的两数各对应的二进位相与,a,b。
按位与运算通常用来对某些位清0或保留某些位;
}
if(add&0x80==1)
==
add&0x80永远不可能为1。例如把a
的高八位清
0
;n",c,
保留低八位,
可作
a&255
运算
(
255
的二进制数为0000000011111111);&"。
按位与运算
按位与运算符"。参与运算的数以补码方式出现;nb=%d\:
00001001
(9的二进制补码)&00000101
(5的二进制补码)
00000001
(1的二进制补码)可见9&5=1;nc=%d\,c);
c=a&b&是位与的意思,如果两个数对应的两进制位都为1,结果位才为1
,此位为1;;是双目运算符;
printf("。
0x80的最后一位是0,否则为0。
main(){
int
a=9
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
a&b中的&是按位与操作,其规则为,
当a和b对应位上的值均为1时,结果的该位上为1,否则结果该位上为0。
即
1&1=1
1&0=0
0&1=0
0&0=0
所以,a&b结果为1的情况有很多种,只要a和b的最低位均为1,其它位上均不同时为1即可。
如
0x33
&
0x41
或
0xff
&
0x01
等等。
当a和b对应位上的值均为1时,结果的该位上为1,否则结果该位上为0。
即
1&1=1
1&0=0
0&1=0
0&0=0
所以,a&b结果为1的情况有很多种,只要a和b的最低位均为1,其它位上均不同时为1即可。
如
0x33
&
0x41
或
0xff
&
0x01
等等。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
0x80的二进制是10000000
add&0x80
==
1
也就是add
&
0x80
!=0
也就是add的二进制形式的第一位必须是1,不能是0
因为不管add值是多少,假如是0xxxxxxx的话(x可能是0可能1)
那么0xxxxxxx
&
10000000
==
0
只有add是1xxxxxxx(x可能是0,可能是1)的时候,1xxxxxxx
&
10000000
!=0
&是位与运算,2个操作数的二进制数对应的每一位进行与运算,1&1=1,1&0=0,0&1=0,0&0=0
add&0x80
==
1
也就是add
&
0x80
!=0
也就是add的二进制形式的第一位必须是1,不能是0
因为不管add值是多少,假如是0xxxxxxx的话(x可能是0可能1)
那么0xxxxxxx
&
10000000
==
0
只有add是1xxxxxxx(x可能是0,可能是1)的时候,1xxxxxxx
&
10000000
!=0
&是位与运算,2个操作数的二进制数对应的每一位进行与运算,1&1=1,1&0=0,0&1=0,0&0=0
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
a&b,
只有:
当
a
和b
最低位
同时等于
1,
并且,
其他位不同时等于1,
才
等于1,
add&0x80==1
永不成立.
(add&0x80)
>>
7
==1
--
最高位等于1
就
成立.
只有:
当
a
和b
最低位
同时等于
1,
并且,
其他位不同时等于1,
才
等于1,
add&0x80==1
永不成立.
(add&0x80)
>>
7
==1
--
最高位等于1
就
成立.
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询