参考博客: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