关闭

“黑马程序员” java位逻辑运算符

113人阅读 评论(0) 收藏 举报

------<a href="http://www.itheima.com" target="blank">Java培训、Android培训、iOS培训、.Net培训</a>、期待与您交流! -------

     移位运算符面向的运算对象也是二进制的“位”。可单独用它们处理整数类型(主类型的一种)。左移位运算符(<<)能将运算符左边的运算对象向左移动运算符右侧指定的位数(在低位补0)。“有符号”右移位运算符(>>)则将运算符左边的运算对象向右移动运算符右侧指定的位数。“有符号”右移位运算符使用了“符号扩展”:若值为正,则在高位插入0;若值为负,则在高位插入1。Java也添加了一种“无符号”右移位运算符(>>>),它使用了“零扩展”:无论正负,都在高位插入0。这一运算符是C或C++没有的。   
  若对char,byte或者short进行移位处理,那么在移位进行之前,它们会自动转换成一个int。只有右侧的5个低位才会用到。这样可防止我们在一个int数里移动不切实际的位数。若对一个long值进行处理,最后得到的结果也是long。此时只会用到右侧的6个低位,防止移动超过long值里现成的位数。但在进行“无符号”右移位时,也可能遇到一个问题。若对byte或short值进行右移位运算,得到的可能不是正确的结果(Java   1.0和Java   1.1特别突出)。它们会自动转换成int类型,并进行右移位。但“零扩展”不会发生,所以在那些情况下会得到-1的结果。


>>右移;<<”左移;>>>”无符号右移

 1 << 3  1*(2*2*2) = 8

 4 >> 2  4/(2*2) = 1

无符号右移

System.out.println(-3>>>1);

1111 1111 1111 1111 1111 1111 1111 1101无符号右移,高位补0,

01111 1111 1111 1111 1111 1111 1111 1110,其为2147483646的原码.

无论正数、负数,它们的右移、左移、无符号右移32位都是其本身,比如 -5<<32=-5、-5>>32=-5、-5>>>32=-5

位逻辑运算符

&”与;“|”或;~”非;^”异或

&”与;“|”或;~”非是基本逻辑运算,由此可以演变出“与非”、“或非”、“与或非”符合逻辑运算、“^”异或是一种特殊的逻辑运算,对它求反可以得到“同或”,所以“同或”逻辑也要“异或非”逻辑。

“&”两个运算数都为1时,结果为1,其余结果为0
“ | ”
两个运算数都为0时,结果为0,其余结果为1
“ ^ “
两个运算数相同时,结果为0,不同时结果为1
” ~ “0
变成11变成0

布尔运算符

&&:对运算数进行与运算,当所有的运算数都为true时,结果为true,否则为false&&是短路与,意思是:当对运算数的表达式进行从左到右运算时,若遇到右运算数的值为false,则结束运算,将结果置为false

||:对运算数进行运算,当所有运算数都为false时,结果为false,否则结果为true||是短路或,意思是:当对运算数的表达式进行从左到右的运算时,若遇到有运算数的值为ture,就结束运算,将结果置为true

:对运算数的值进行取反运算,运算数为true,取反为false

&&运算符和&&一样,对运算数做与操作,不同的是它不是短路的,它会运算完所有的运算数表达式

||运算符和||一样,对运算数进行或操作,但它不是短路的

赋值运算符=+=-=*=/=&=|=^=

i+=j ------ i=i+j

i-=j ------ i=i-j

i*=j ------ i=i*j

i/=j ------ i=i/j

i&=j ------ i=i&j

i|=j ------ i=i|j

i^=j ------ i=i^j


0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:974次
    • 积分:104
    • 等级:
    • 排名:千里之外
    • 原创:10篇
    • 转载:0篇
    • 译文:0篇
    • 评论:0条
    文章存档