• Java的位运算符——&0xFF的运算与讲解


    快放元旦假,没心思做啥的事,就去翻以前的代码遇到这句,但是又不懂,所以只好上网找,终于懂了那么一点点。

    所以那个大神看到我说的有问题,请指出!谢谢。。。。

     一:首先区分一下 A~F的意思先

    A,代表十进制的10,二进制的1010。
    B,代表十进制的11,二进制的1011。
    C,代表十进制的12,二进制的1100。
    D,代表十进制的13,二进制的1101。
    E,代表十进制的14,二进制的1110。
    F,代表十进制的15,二进制的1111。
    e
    二:区分
    &,丨,^的运算规则
    & (按位与运算符)表示:
    两个操作数中位都为1,结果为1
    如果两个操作中位一个1另一个0 ,结果为0
    即运算规则:0&0=0; 0&1=0; 1&0=0; 1&1=1;
    例如:1010 & 1110= 1010

    |(按位或运算符)表示:
    两个操作中位只有一个为1,结果就等与1
    即运算规则:0|0=0; 0|1=1; 1|0=1; 1|1=1

    例如: 1010 | 1111 =1111

    ^(异或 运算符)表示
    两个中位如果相同的数值,结果为 0,
    如果两个中位 数值不同,结果为1.
    即运行结果:同数值: 0^0=0;1^1=0;
    不同数值: 0^1=1; 1^0=1;

    例如:1010 ^ 1110 = 0100

     ~(取反运算符)表示:(这个我不太懂)
    参加运算的一个数据,按二进制位进行“取反”运算。
    即:对一个二进制数按位取反,即将0变1,1变0
    运算规则:~1=0; ~0=1;

    例如:使一个数的最低位为零,可以表示为:a&~1
    ~1的值为1111111111111110

      

     3:0x31 (一般看到0x==》16进制数)

           0x31计算: 先把0x31转换为 10进制的数  0x31(10)=16*3+1=49

             再把得到10进制转 2进制    49(2)=110001

      所以 0xFF 也是这样计算的  F==>表示15进制

            0xFF(10)= 16*15+15=255

             255 (2) = 11111111

       0x31  &  0xFF 的 计算 

       因为0xFF得出的结果 8个字节,而位数要相同,那么 0x31就要补0,因为在0x31的二进制为110001已经又6个字节了,那么再前面加两个0即可(这句其实我觉得我说的有点怪怪的)

      a): 0x31 &  0xFF

     = 00110001 &  11111111

     =00110001          

     =110001

     b):  0x31  |  0xFF 

      = 00110001  |  11111111

      =11111111 

     

  • 相关阅读:
    python易错点2
    python易错点1
    Spring:注解组件注册
    KubeSphere建立多租户系统
    Centos7.7下KubeSphere最小化安装和定制化配置安装
    安装create-react-app
    查看react版本等信息
    react自动生成React组件命令
    sqlserver 随机数
    Error while downloading 'http://java.sun.com/xml/ns/javaee/javaee_web_services_client_1_2.xsd'
  • 原文地址:https://www.cnblogs.com/zhu520/p/8143688.html
Copyright © 2020-2023  润新知