zoukankan      html  css  js  c++  java
  • Go位运算

    &       位运算 AND  
    |       位运算 OR  
    ^       位运算 XOR  
    &^      位运算 (AND NOT)
    <<      左移
    >>      右移    
    

    &(AND)

    & 运算:相同位的两个数字都为1,则为1;若有一个不为1,则为0。

    0000 0100   4
    0000 0110   6
    ---------
    0000 0100   4
    

    |(OR)

    | 运算:相同位只要一个为1即为1。

    0000 0100   4
    0000 0110   6
    ---------
    0000 0110   6
    

    ^(XOR)

    作为二元运算:相同位不同则为1,相同则为0。

    0000 0100   4
    0000 0110   6
    ---------
    0000 0010   2
    

    作为一元运算:按位取反。
    涉及知识点,参考:博文

    所有正整数的按位取反是其本身+1的负数
    所有负整数的按位取反是其本身+1的绝对值
    零的按位取反是 -1
    
    0000 0100   4 原码
    0000 0100   4 补码
    1111 1011   4的补码取反记为 x
    1111 1010   x-1 得到反码记为 y
    1111 0101   y 取反得到源码,此为最终结果 -5
    

    &^(AND NOT)

    &^ 运算:位清空运算,和被运算变量位置有关系。计算x&^y 如果ybit位上的数是0则取x上对应位置的值, 如果ybit位上为1则取结果位上取0

    0000 0100   4 记为 x
    0000 0110   6 记为 y
    ---------
    0000 0000   0
    

    << 和 >>

    << 运算:a << b就表示把a转为二进制后左移b位(在后面添b个0)。
    >> 运算:a >> b表示二进制右移b位(去掉末b位),相当于a除以2的b次方(取整)。

    0000 0100   4
    0000 1000   4 << 1 = 8
    0001 0000   4 << 2 = 16
    
    0000 0110   6
    0000 0011   6 >> 1 = 3
    0000 0001   6 >> 2 = 1
    
  • 相关阅读:
    Java 泛型
    Github
    软件工程----前端
    前端全局缓存的三种方式
    关于IDE的选择
    模拟placeholder
    小程序request封装
    小程序实现大转盘抽奖----踩坑之路
    关于this的理解
    小程序背景图片bug
  • 原文地址:https://www.cnblogs.com/wuyongqiang/p/11888745.html
Copyright © 2011-2022 走看看