按位与& 逻辑与&& 按位或| 逻辑或|| 及其应用

按位与&  逻辑与&&  按位或|  逻辑或||  及其应用

结果:1&2 = 0 1&&2 = 1

结果:

概念: 掩码英语:Mask)在计算机学科及数字逻辑中指的是一串二进制数字,通过与目标数字的按位操作,达到屏蔽指定位而实现需求。

          子网掩码:eg:255.255.255.0 则与ip进行按位与运算,从而让掩码与ip地址做按位与运算时用0遮住原主机数,而不改变原网络段数字,而且很容易通过0的位数确定子网的主机数(2的主机位数次方-2,因为主机号全为1时表示该网络广播地址全为0时表示该网络的网络号,这是两个特殊地址)。只有通过子网掩码,才能表明一台主机所在的子网与其他子网的关系,使网络正常工作。

应用:

  1. 用于掩码。参考如上概念

  2. 用于条件判断。

            enum CommandStatus{

                CMD_PREVIEW_START_PREPARE             = 0x01,

                CMD_PREVIEW_START_DONE                = 0x02,    

                CMD_PREVIEW_START_MASK                = 0x03,

        

                CMD_PREVIEW_STOP_PREPARE            = 0x04,

                CMD_PREVIEW_STOP_DONE                = 0x08,

                CMD_PREVIEW_STOP_MASK                = 0x0C,

            };

            if(status&CMD_PREVIEW_START_PREPARE)

            {

                mCameraStatus |= CMD_PREVIEW_START_PREPARE;

            }

        3. 取地位或高位操作。如通常使用0x0f来与一个整数进行&运算,来获取该整数的最低4bit位,例如,0x31 & 0x0f的结果为0x01

部分 reference:https://www.cnblogs.com/wudongyang/p/4340003.html

&

表示按位与。

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

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

15&127为什么等于15啊? 

15二进制: (0000 1111)

127二进制: (1111 1111)

按位与自然就是(0000 1111)=15

 

&&

表示逻辑与的意思,即为and。当运算符两边的表达式的结果都为true时,整个运算结果才为true,否则,只要有一方为false,则结果为false。

比如 12&&23的结果就是1,12&&-1 的结果是1,123&&0的结果就是0

 

&&还具有短路的功能,即如果第一个表达式为false,则不再计算第二个表达式,例如,对于if(str != null && !str.equals(“”))表达式,当str为null时,后面的表达式不会执行,所以不会出现NullPointerException

 

|

表示按位或

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

128:     (0001 0000 0000)

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

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

 

||

表示逻辑或

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

12||1 =1  12||0 =1 0||0 =0

你可能感兴趣的:(代码风格基础,c,road)