如何使用位掩码检查字节流中的一个字节

how to check a byte inside of stream of bytes using bitmask

我有 bytebuffer 并且我每次迭代读取 8 个字节(长)我有我想比较的位掩码,但我不确定我的模式应该是什么样子。例如,

private final static long ASCII_125 = 0x7D;

public static boolean isValidPath(
        DirectBuffer path)
{
  boolean isPathValid = true;
  for (int i = 0; i < path.capacity(); i += Long.BYTES)
  {
      long charsLong = path.getLong(i);
      if ((charsLong & result) != xxxxxx(pattern))
      {
          isPathValid = false;
          break;
      }
  }
  return isPathValid;
}

所以如果charlong是0b01111011_01111011_00100101_00100101_01111011_01111011_01111101_01111101,检查这8个字节中是否存在01111101字节。我想我需要找到逻辑上让我一次检查多个值的模式,为该模式构建一个掩码,然后一次将掩码应用于所有 8 个字节。但是我很难想出模式。

这样的事情怎么样:

这基本上是通过将长右移 8 位并将其屏蔽为 一个字节。

  for (int i = 0; i < path.capacity(); i += Long.BYTES) { 
      long charsLong = path.getLong(i);
      while(charsLong > 0) {
          // get low order byte
          byte val = (byte)(charLong&0xFF);
          if ((val & result) != xxxxxx(pattern)) {
             return false;
          }
          // right shift thru sign bit by 8 bits 
          charsLong>>>= 8; 
      }
   }
   return true;

请注意,如果您正在检查特定字节值,您可以将每个字节与结果字节进行比较。但是如果你想检查并查看字节中是否设置了某些位,那么你需要一个位掩码。

例如要查看是否设置了低阶 101 位,您可以执行以下操作。

byte bitMask = 0b101;

if ((test & bitMask) == bitMask) {
   bits are set.
}