c++/c中的中运算符 &和&&、|和||

23 篇文章 2 订阅

参考博客:https://www.cnblogs.com/kuihuayou/p/7365075.html

https://blog.csdn.net/violet_echo_0908/article/details/47395875

概念:

&&是逻辑与运算符,||是逻辑或运算符,都是逻辑运算符,两边只能是bool类型 
&与| 既可以进行逻辑运算,又可以进行位运算,两边既可以是bool类型,又可以是数值类型

&&:表示逻辑与的意思,即为and。

当运算符两边的表达式的结果都为true时,整个运算结果才为true,否则,只要有一方为false,则结果为false。(也就是必须双方同为true,这个最后的结果才是true)

比如 1&&10的结果就是1,1&&-1 的结果是0,15&&0的结果就是0

&:表示按位与。

&表示按位与操作,我们通常使用0x0f来与一个整数进行&运算,来获取该整数的最低4个bit位,例如,0x31 & 0x0f的结果为0x01。

二进制与运算规则:1&1=1  1&0=0  0&0=0

10&127

10二进制: ( 0000 1010)

127二进制: (111 1111)

按位与自然就是(111 1010)=122

||:表示逻辑或

 逻辑或,是逻辑运算符,符号是“||”(在PASCAL中为"or")。 “逻辑或”相当于生活中的“或者”,当两个条件中有任一个条件满足,“逻辑或”的运算结果就为“真” 

如: 1|| 2 = 1, 10|| -1 = 1, 0 || 0 = 0

|表示按位或

按位或运算 按位或运算符“|”是双目运算符。其功能是参与运算的两数各对应的二进位(也就是最后一位)相或。只要对应的二个二进位有一个为1时,结果位就为1。(按位进行或,只要有一个为或的话,结果就是为或)

128:     (000 1000 0000)

127:     (0000 111 1111) (高位用0补齐)

按位或就是(000 1111 1111)=255

 

 

 

 

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值