按位与(&)按位或(|)异或(^) 的运算方式

本文介绍了C语言中按位与(&)、按位或(|)和按位异或(^)的运算规则。通过具体的二进制示例,展示了如何进行这些位操作,并解释了每个运算符如何影响二进制数字的每一位,从而得出最终的运算结果。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    在计算机语言中,数字的表现形式其实是以二进制方式保存,比如

    int a = 1 ;

    并不是直接将1赋予a,由于1是整型,所以在内存中开辟了一块四个字节大小(一个8个比特位)的空间来存放,但存放的并不是1这个是数字,而是一个32个比特位的二进制数1,即00000000000000000000000000000001。

    而这个

按位与(&)

    二进制位都为1才是1,否则为0;

例如:

9:00000000000000000000000000001001

3:00000000000000000000000000000011

9&3则是:

都是0,所以红框内二进制位都是0。

红框内为0和1,所以为0;

最后一位都为1,才是1;

所以9&3的结果为00000000000000000000000000000001=1;

按位或(|)

二进制位有1则为1,都为0才是0;

9:00000000000000000000000000001001

3:00000000000000000000000000000011

9|3的结果为

00000000000000000000000000001011=11;

按位异或(^)

二进制位不相同1,其他为0;

9:00000000000000000000000000001001

3:00000000000000000000000000000011

9^3=

     00000000000000000000000000001010=10

&(与):真真为真,一假为假(一为0,则为0)(例如:  0011&0101 = 0001)

| (或):一真为真,假假为假(一为1,则为1)(例如:  0011|0101 =0111)

~(非):真为假,假为真(~0011 = 1100)

^(异或):不同为真,相同为假(例如:  0011|0101 =1001)

<<(左移):二进制向左移动一位,末尾补0  

>>(右移):  二进制向右移动一位   101101 >>1    101101->10110
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值