• 位运算的分类


    位运算:是直接对整数在内存中的二进制位进行操作,效率高。

    位运算的分类:

      ~ 按位取反
      ^ 异或
      | 按位或
      & 按位与
      && 逻辑与
      || 逻辑或
      ! 逻辑非
      << 左移
      >> 右移
      >>> 右移 0填充

    为了方便,以下二进制位以8位。

    位与&:是参与运算的两数各对应的二进位相与,
    有0为0,全1为1.

    1&2=0
    0000 0001 ------1
    0000 0010 ------2
    ---------
    0000 0000 ------0

    位或|:是参与运算的两数各对应的二进位相或,
    有1为1,全0为0.

    1|3=3
    0000 0001 ------1
    0000 0011 ------3
    ---------
    0000 0011 ------3

    异或^:是参与运算的两数各对应的二进位相异或,
    当两对应的二进位相异时,结果为1;相同时,结果为0.

    1^5=8
    0000 0001 ------1
    0000 0101 ------5
    ----------
    0000 0100 ------8

    以上三种无论前者是真还是假,都要判断第二个数。

    逻辑与&&:
    0&&0=0
    0&&1=0
    1&&0=0
    1&&1=0

    前者为假时,不用判断后者。

    逻辑或||:
    0||0=0
    0||1=1
    1||0=1
    1||1=1

    前者为真时,不用判断后者。

    逻辑非!:
    !0=1
    !1=0

    左移<<:左边的位被挤掉。对于右边移出的空位,则空位补0.其值相当于乘2.

    3<<2=12

    0 0 1 1 -----3
    1 1 x x -----x为0,即为 1 1 0 0
    --------
    1 1 0 0 -----12


    右移>>:右边的位被挤掉。对于左边移出的空位,如果是正数则空位补0;
    若为负数,可能补0或补1(符号位),这取决于所用的计算机系统。
    其值相当于除以2.

    12>>1=6

    1 1 0 0 -----12
    x 1 1 0 -----x为0,即为0 1 1 0
    --------
    0 1 1 0 -----6

    按位取反~:

    ~6=9

    0 1 1 0 ------6
    1 0 0 1 ------9

    1和0互换

    运算符>>>:右边的位被挤掉。对于左边移出的空位一概补上0;

  • 相关阅读:
    IOS 获取时间的问题
    JQ 点赞
    截取字符串第一个空格前的字符
    JQ 的一些方法
    匿名函数var a =function(){}和function a(){}的区别
    完美支持中文编程的 Emacs 配置文件 .emacs
    linux find 命令忽略某个或多个子目录的方法
    Linux下如何用date设置时间
    nagios的监控代码!
    shell脚本监控apache进程数和oracle连接数
  • 原文地址:https://www.cnblogs.com/gd-luojialin/p/6635609.html
Copyright © 2020-2023  润新知