逻辑操作符、位操作符号的忽略点

 

研究生要毕业了,最近要开始找工作,随便翻看一下基础知识。

逻辑操作符和位操作符都是操作符分类中的一种。

说明两个问题:

第一:短路逻辑操作符和非短路逻辑操作符的区别

        短路逻辑与(&&)    短路逻辑或(||)   非短路逻辑与(&)  非短路逻辑或(|)

        短路的意思就是,计算左操作数后,如果能决定表达式的值,那就不计算右操作数。

        如: if(1==2&&1==1)  //左操作数为假,表达式就一定为假了,就不计算右操作数了

        非短路的意思就是,左右操作数都要计算完,才计算表达式的值 

         如: if(1==2&1==1)  //先计算左操作数为假,右操作数为真,然后,真假为假

         其实,基本用到的就是短路操作符,相比而言,其效率更高,非短路的我是很少用到的目前

         不过,&和|也可以作为位操作符使用,这个可是经常用到的。

          &:按位与    |:按位或    与:1,1为1,其他为0。或 0,0为0,其他为1。

         别的基础的不说了!

第二:关于位操作符>>   >>>   <<的问题

         >>:算术右移,左边直接补全符号位       >>>:逻辑右移,左边直接补全0      <<:算术左移,右边直接补全0

         对于算术左移和算术右移,有计算公式:

          a<<b   <=>  a*2的  b%(a类型的bit数)  次方

          a>>b    <=>  a/2的   b%(a类型的bit数)  次方  前提是:|a|>=|b|

          例如:  -1>>1   用上面的公式算的话就是0。其实不是

                    就拿整数的默认类型int来说

                    对于-1      原码:10…………01

                                   反码:11…………10       

                                                        +1       负数的补码是原码取反再+1

                                   补码:11…………11

                     所以说,对于-1的算术右移,其值是不变的,还是-1。因为补全的是符号位1。

                     对于逻辑右移,补全的是0。就变成了

                                   补码:01…………11      正数的原码即补码

                                   原码:01…………11        <=> 2147483647

                  正数和负数在计算机的存储虽说都是二进制,但是,实质是不一样的。

                  正数在计算机上存储的是原码        负数存储的是补码

                  位操作的本质:是对计算机上存储的二进制位进行操作的。

                  如上面的左右移,对于正数,移动的是原码 ,对于负数,移动的是补码。

                  正数的原码就是补码。负数的原码取反再+1才是补码。

                  所以才会有

                                  -1>>1  为-1

                                -1>>>1 为2147483647

        

 

posted @ 2015-05-13 11:28  大数据从业者FelixZh  阅读(934)  评论(0编辑  收藏  举报