zoukankan      html  css  js  c++  java
  • java 位运算(经常用到)

    1.表示方法:  

    在Java语言中,二进制数使用补码表示,最高位为符号位,正数的符号位为0,负数为1。补码的表示需要满足如下要求。  

    (1)正数的最高位为0,其余各位代表数值本身(二进制数)。  

    (2)对于负数,通过对该数绝对值的补码按位取反,再对整个数加1。 

    2、具体算法符及运算规则

    // 1、左移( << ) // 0000 0000 0000 0000 0000 0000 0000 0101 然后左移2位后,低位补0://
    // 0000 0000 0000 0000 0000 0000 0001 0100 换算成10进制为20
    System.out.println(5 << 2);
    // 运行结果是20
    // 2、右移( >> ) 高位补符号位
    // 0000 0000 0000 0000 0000 0000 0000 0101 然后右移2位,高位补0:
    // 0000 0000 0000 0000 0000 0000 0000 0001
    System.out.println(5 >> 2);// 运行结果是1
    // 3、无符号右移( >>> ) 高位补0
    // 例如 -5换算成二进制后为:0101 取反加1为1011
    // 1111 1111 1111 1111 1111 1111 1111 1011
    // 我们分别对5进行右移3位、 -5进行右移3位和无符号右移3位:
    System.out.println(5 >> 3);// 结果是0 System.out.println(-5 >> 3);// 结果是-1
    System.out.println(-5 >>> 3);// 结果是536870911
    // 4、位与( & )
    // 位与:第一个操作数的的第n位于第二个操作数的第n位如果都是1,
    那么结果的第n为也为1,否则为0
    System.out.println(5 & 3);
    // 结果为1 System.out.println(4 & 1);// 结果为0
    // 5、位或( | )
    // 第一个操作数的的第n位于第二个操作数的第n位
    只要有一个是1,那么结果的第n为也为1,否则为0
    System.out.println(5 | 3);// 结果为7
    // 6、位异或( ^ )
    // 第一个操作数的的第n位于第二个操作数的第n位
    相反,那么结果的第n为也为1,否则为0
    System.out.println(5 ^ 3);//结果为6
    // 7、位非( ~ )
    // 操作数的第n位为1,那么结果的第n位为0,反之。
    System.out.println(~5);// 结果为-6
  • 相关阅读:
    c++ 虚继承与继承的差异 (转)
    主题:PageRank解释
    (转)开源爬虫larbin分析
    Django随笔
    原生爬虫小Demo
    SVN
    Python的正则表达式与JSON
    类库 方法 模块等
    笔记
    自动补全Typeahead
  • 原文地址:https://www.cnblogs.com/qqzhulu/p/10129163.html
Copyright © 2011-2022 走看看