美文网首页
Java位运算

Java位运算

作者: ZMRWEGo | 来源:发表于2018-11-01 11:09 被阅读1次

    java各类转化
    字节数组 <----->二进制数字、十进制、16进制、字符串

    二进制(Binary)<------->十进制(decimal) 16进制(hex)
    二进制编码 <-----> 字符串
    16进制编码 <------->字符串

    十进制 ----> 16进制
    对于 c/c++ 基本数据类型分配的字节随着操作系统的位数(32位、64位)变化而不同


    int:4 个字节。

    short:2 个字节。

    long:8 个字节。

    byte:1 个字节。 (0 - 255)

    float:4 个字节。

    double:8 个字节。

    char:2 个字节。

    boolean:boolean属于布尔类型,在存储的时候不使用字节,仅仅使用 1 位来存储,范围仅仅为0和1,其字面量为true和false。

    原码:
    讲一个数字转化为二进制 就是其原码
    int a =5 0000 0000 0000 0101(32位二进制数 由于加入正负数 所以最高位0表示正数 1表示负数 一般较小的数 不需要将32位全写出来)
    int a =-1 1000 0000 0000 0001
    反码:

    • 正数的反码就是其原码
    • 负数的反码就是 符号位不变,其余位置都取反
      5 的反码 0000 0000 0000 0101
      -1 的反码 1111 1111 1111 1110
      补码:
    • 正数的补码为其本身
    • 负数的补码为其在反码的基础上加1
      5的补码 0000 0000 0000 0101
      -1的补码 1111 1111 1111 1111
      注: 计算机在进行计算的时候是通过补码进行计算的,得到的是数字的原码

    5 - 1 = 0000 0000 0000 0101
    + 1111 1111 1111 1111
    = 0000 0000 0000 0100 = 4


    位运算符& | ~ ^ >> <<
    与运算:
    0 & 1 = 0
    1 & 1 = 1
    例如正数 5 & 1 = 0000 0000 0000 0001 =1
    或运算:
    0 | 0 = 0
    0 | 1 =1
    例如正数 5 | 1 = 0000 0000 0000 0101 =5
    取反运算(与反码不同):
    ~5 = 1111 1111 1111 1010
    异或运算:相同为1 不行同为0
    1 ^ 0 = 0
    1 ^ 1 = 1
    例如数字 5 ^ 1 = 0000 0000 0000 0001 = 1
    异或可作为简单的数据加密形式
    例如将一个MP4文件所有数值与种子数值进行异或,进行加密,解密时与种子数值再进行异或一次即可

    右移运算:将数值 a 的二进制数值从 0 位算起到第 b - 1 位,整体向右方向移动 b 位,符号位不变,高位空出来的位补数值 0。
    5 >> 1 ===> 0000 0000 0000 0101 ==> 0000 0000 0000 0010 = 2

    <<左移运算: a << b 将数值 a 的二进制数值从 0 位算起到第 b - 1 位,整体向左方向移动 b 位,符号位不变,低位空出来的位补数值 0。
    5 << 1 ===> 0000 0000 0000 0101 << 1 = 0000 0000 0000 1010 = 10

    相关文章

      网友评论

          本文标题:Java位运算

          本文链接:https://www.haomeiwen.com/subject/wywtxqtx.html