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


     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

    i++:后加加,在表达式中,变量i先参与运算,再完成自增加1

    ++i:前加加,在表达式中,变量i先完成自增1,再参与运算

    • i++ 先赋值再运算,即先 a = i,后 i = i+1;
    • ++i 先运算再赋值,即先 i = i+1,后 a = i;

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

  • 相关阅读:
    构建之法阅读笔记06
    钢镚儿开发前会议
    构建之法阅读笔记05
    4.11第8周学习总结
    人月神话阅读笔记01
    构建之法阅读笔记04
    4.4日学习总结
    构建之法阅读笔记03
    3.28第六周学习内容总结
    二人团队项目增删改查
  • 原文地址:https://www.cnblogs.com/dingpeng9055/p/11725616.html
Copyright © 2020-2023  润新知