关于java位运算以及一段类似base64加密

技术教程 2年前 (2018) Mgo
0


public final class b
  implements Serializable
{
  private static final char[] legalChars = "ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/".toCharArray();
  
  private static int decode(char paramChar)
  {
    if ((paramChar >= 'A') && (paramChar <= 'Z')) {
      return paramChar - 'A';
    }
    if ((paramChar >= 'a') && (paramChar <= 'z')) {
      return paramChar - 'a' + 26;
    }
    if ((paramChar >= '0') && (paramChar <= '9')) {
      return paramChar - '0' + 26 + 26;
    }
    switch (paramChar)
    {
    default: 
      return -1;
    case '+': 
      return 62;
    case '/': 
      return 63;
    }
    return 0;
  }
  
  private static void decode(String paramString, OutputStream paramOutputStream)
  {
    int i = 0;
    int j = paramString.length();
    for (;;)
    {
      if (i < j) {}
      try
      {
        if (paramString.charAt(i) > ' ')
        {
          if (i != j)
          {
            int k = (decode(paramString.charAt(i)) << 18) + (decode(paramString.charAt(i + 1)) << 12) + (decode(paramString.charAt(i + 2)) << 6) + decode(paramString.charAt(i + 3));
            paramOutputStream.write(k >> 16 & 0xFF);
            if (paramString.charAt(i + 2) != '=')
            {
              paramOutputStream.write(k >> 8 & 0xFF);
              if (paramString.charAt(i + 3) != '=')
              {
                paramOutputStream.write(k & 0xFF);
                i += 4;
              }
            }
          }
        }
        else {
          i += 1;
        }
      }
      catch (IOException paramString)
      {
        paramString.printStackTrace();
      }
    }
  }
  
  /* Error */
  public static byte[] decode(String paramString)
  {

  }
  
  public static String encode(byte[] paramArrayOfByte)
  {
    int k = paramArrayOfByte.length;
    StringBuffer localStringBuffer = new StringBuffer(paramArrayOfByte.length * 3 / 2);
    int i = 0;
    int j = 0;
    for (;;)
    {
      if (j > k - 3)
      {
        if (j != k + 0 - 2) {
          break label254;
        }
        i = (paramArrayOfByte[j] & 0xFF) << 16 | (paramArrayOfByte[(j + 1)] & 0xFF) << 8;
        localStringBuffer.append(legalChars[(i >> 18 & 0x3F)]);
        localStringBuffer.append(legalChars[(i >> 12 & 0x3F)]);
        localStringBuffer.append(legalChars[(i >> 6 & 0x3F)]);
        localStringBuffer.append("=");
      }
      for (;;)
      {
        return localStringBuffer.toString();
        int m = (paramArrayOfByte[j] & 0xFF) << 16 | (paramArrayOfByte[(j + 1)] & 0xFF) << 8 | paramArrayOfByte[(j + 2)] & 0xFF;
        localStringBuffer.append(legalChars[(m >> 18 & 0x3F)]);
        localStringBuffer.append(legalChars[(m >> 12 & 0x3F)]);
        localStringBuffer.append(legalChars[(m >> 6 & 0x3F)]);
        localStringBuffer.append(legalChars[(m & 0x3F)]);
        j += 3;
        if (i < 14) {
          break label319;
        }
        localStringBuffer.append(" ");
        i = 0;
        break;
        label254:
        if (j == k + 0 - 1)
        {
          i = (paramArrayOfByte[j] & 0xFF) << 16;
          localStringBuffer.append(legalChars[(i >> 18 & 0x3F)]);
          localStringBuffer.append(legalChars[(i >> 12 & 0x3F)]);
          localStringBuffer.append("==");
        }
      }
      label319:
      i += 1;
    }
  }
}

位运算符主要针对二进制,它包括了:“与”、“非”、“或”、“异或”。从表面上看似乎有点像逻辑运算符,但逻辑运算符是针对两个关系运算符来进行逻辑运算,而位运算符主要针对两个二进制数的位进行逻辑运算。下面详细介绍每个位运算符。

 


1.与运算符
与运算符用符号“&”表示,其使用规律如下:
两个操作数中位都为1,结果才为1,否则结果为0,例如下面的程序段。
public class data13
{
public static void main(String[] args)
{
int a=129;
int b=128;
System.out.println("a 和b 与的结果是:"+(a&b));
}
}
运行结果
a 和b 与的结果是:128
下面分析这个程序:
“a”的值是129,转换成二进制就是10000001,而“b”的值是128,转换成二进制就是10000000。根据与运算符的运算规律,只有两个位都是1,结果才是1,可以知道结果就是10000000,即128。

 


2.或运算符
或运算符用符号“|”表示,其运算规律如下:
两个位只要有一个为1,那么结果就是1,否则就为0,下面看一个简单的例子。
public class data14
{
public static void main(String[] args)
{
int a=129;
int b=128;
System.out.println("a 和b 或的结果是:"+(a|b));
}
}
运行结果
a 和b 或的结果是:129
下面分析这个程序段:
a 的值是129,转换成二进制就是10000001,而b 的值是128,转换成二进制就是10000000,根据或运算符的运算规律,只有两个位有一个是1,结果才是1,可以知道结果就是10000001,即129。

 


3.非运算符
非运算符用符号“~”表示,其运算规律如下:

如果位为0,结果是1,如果位为1,结果是0,下面看一个简单例子。
public class data15
{
public static void main(String[] args)
{
int a=2;
System.out.println("a 非的结果是:"+(~a));
}
}

 


4.异或运算符
异或运算符是用符号“^”表示的,其运算规律是:
两个操作数的位中,相同则结果为0,不同则结果为1。下面看一个简单的例子。
public class data16
{
public static void main(String[] args)
{
int a=15;
int b=2;
System.out.println("a 与 b 异或的结果是:"+(a^b));
}
}
运行结果
a 与 b 异或的结果是:13
分析上面的程序段:a 的值是15,转换成二进制为1111,而b 的值是2,转换成二进制为0010,根据异或的运算规律,可以得出其结果为1101 即13。

版权声明:Mgo 发表于 2018-10-23 16:49:36。
转载请注明:关于java位运算以及一段类似base64加密 | 站长聚集地

暂无评论

暂无评论...