码迷,mamicode.com
首页 > 编程语言 > 详细

java中位运算^,&,<<,>>,<<<,>>>

时间:2019-10-23 13:11:48      阅读:83      评论:0      收藏:0      [点我收藏+]

标签:log   一个   round   params   pre   java   反码   param   不同   

 1.^(亦或运算) ,针对二进制,相同的为0,不同的为1

public static void main(String[] args) {
    System.out.println("2^3运算的结果是 :"+(2^3));
    //打印的结果是:   2^3运算的结果是 :1
}

2 =======>0010

3 =======>0011

2^3就为0001,结果就是1

 

2.&(与运算) 针对二进制,只要有一个为0,就为0

还是上述的例子

public static void main(String[] args) {
         System.out.println("2&3运算的结果是 :"+(2&3));
         //打印的结果是:   2&3运算的结果是 :2
     }

3 <<表示左移移,不分正负数,低位补0 

注:以下数据类型默认为byte-8位

左移时不管正负,低位补0

正数:r = 20 << 2

  20的二进制补码:0001 0100

  向左移动两位后:0101 0000

         结果:r = 80

负数:r = -20 << 2

  -20 的二进制原码 :1001 0100

  -20 的二进制反码 1110 1011

  -20 的二进制补码 :1110 1100

  左移两位后的补码:1011 0000

        反码:1010 1111

        原码:1101 0000

        结果:r = -80

4  >>表示右移,如果该数为正,则高位补0,若为负数,则高位补1;

注:以下数据类型默认为byte-8位

正数:r = 20 >> 2

  20的二进制补码:0001 0100

  向右移动两位后:0000 0101

       结果:r = 5

负数:r = -20 >> 2

  -20 的二进制原码 :1001 0100

  -20 的二进制反码 :1110 1011

  -20 的二进制补码 :1110 1100 

  右移两位后的补码:1111 1011 

        反码:1111 1010

        原码:1000 0101

        结果:r = -5

5  >>>表示无符号右移,也叫逻辑右移,即若该数为正,则高位补0,而若该数为负数,则右移后高位同样补0

正数: r = 20 >>> 2

    的结果与 r = 20 >> 2 相同;

负数: r = -20 >>> 2

注:以下数据类型默认为int 32位

  -20:源码:10000000 00000000 00000000 00010100

    反码:11111111  11111111   11111111   11101011

    补码:11111111  11111111   11111111   11101100

    右移:00111111  11111111   11111111   11111011

    结果:r = 1073741819

 https://www.cnblogs.com/chuijingjing/p/9405598.html

java中位运算^,&,<<,>>,<<<,>>>

标签:log   一个   round   params   pre   java   反码   param   不同   

原文地址:https://www.cnblogs.com/dingpeng9055/p/11725616.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!