C语言位运算详解(初稿)

 C语言位运算(按位与运算、或运算、异或运算、左移运算、右移运算)

所谓"位运算",就是一个对 比特 "Bit" 位 进行操作。

比特Bit 是一个电子元器件, 8个比特构成一个 字节(Byte),它已经是粒读最小的可操作单元!

C语言提供了 "六种运算符":

    运算符     &           |           ^          ~       <<       >>
     说明   按位"与"    按位"或"     按位"异或"     取反     左移     右移


 


一、按位"与"运算( & )

一个 比特"Bit"位 只有 0和1 两个取值,只有参与 & 运算的"两个位"都为1时,结果才为1,否则为0

    例如:1&1为 1,0&0为 0,1&0也为 0,这和逻辑运算符&&非常类似。

"C语言中不能直接使用二进制"

" & " 两边的操作数可以是"十进制八进制十六进制"

它们在内存中最终都是以二进制形式存储

& 就是对这些内存中的二进制位进行运算。其他的位运算符也是相同的道理。

//列如: 9&5 可以转换成如下的运算:

    0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 1001  (9 在内存中的存储)
&   0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 0101  (5 在内存中的存储)
-----------------------------------------------------------------------------------
    0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 0001  (1 在内存中的存储)

也就是说,按位"与"运算会对参与运算的两个数的所有而进行进行 & 运算,9 & 5的结果为 1。

//又如,-9 & 5可以转换成如下的运算:

    1111 1111 -- 1111 1111 -- 1111 1111 -- 1111 0111  (-9 在内存中的存储)
&   0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 0101  (5 在内存中的存储)
-----------------------------------------------------------------------------------
    0000 0000 -- 0000 0000 -- 0000 0000 -- 0000 0101  (5 在内存中的存储)

-9 & 5的结

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值