BitSet与整数/长整数

时间:2010-03-18 21:56:02

标签: java bit-manipulation bitset

如果我有一个我想要执行位操作的整数,我该如何将其加载到java.util.BitSet?如何将其转换回int或long?我不太关心BitSet的大小 - 它总是32或64位长。我只想使用set()clear()nextSetBit()nextClearBit()方法而不是按位运算符,但我找不到一种简单的方法来初始化用数字类型设置位。

6 个答案:

答案 0 :(得分:51)

以下代码从long值创建一个位集,反之亦然:

public class Bits {

  public static BitSet convert(long value) {
    BitSet bits = new BitSet();
    int index = 0;
    while (value != 0L) {
      if (value % 2L != 0) {
        bits.set(index);
      }
      ++index;
      value = value >>> 1;
    }
    return bits;
  }

  public static long convert(BitSet bits) {
    long value = 0L;
    for (int i = 0; i < bits.length(); ++i) {
      value += bits.get(i) ? (1L << i) : 0L;
    }
    return value;
  }
}

编辑:现在两个方向,@ leftbrain:原因,你是对的

答案 1 :(得分:32)

添加到finnw回答:还有BitSet.valueOf(long[])BitSet.toLongArray()。所以:

int n = 12345;
BitSet bs = BitSet.valueOf(new long[]{n});
long l = bs.toLongArray()[0];

答案 2 :(得分:18)

Java 7有BitSet.valueOf(byte[])BitSet.toByteArray()

如果您遇到Java 6或更早版本,则可以使用BigInteger,如果它不太可能是性能瓶颈 - 它有getLowestSetBitsetBit和{{1}方法(最后两个将创建一个新的clearBit,而不是就地修改。)

答案 3 :(得分:3)

&#39; 的方式从 long获取BitSet

long l = bitSet.stream()
        .takeWhile(i -> i < Long.SIZE)
        .mapToLong(i -> 1L << i)
        .reduce(0, (a, b) -> a | b);

反之亦然:

BitSet bitSet = IntStream.range(0, Long.SIZE - 1)
        .filter(i -> 0 != (l & 1L << i))
        .collect(BitSet::new, BitSet::set, BitSet::or);

N.B。:使用BitSet::valueOfBitSet::toLongArray当然更容易。

答案 4 :(得分:1)

非常直接来自nextSetBit的文档

value=0;
for (int i = bs.nextSetBit(0); i >= 0; i = bs.nextSetBit(i+1)) {
 value += (1 << i)
 }

答案 5 :(得分:-3)

public void set(int bit)方法不是您想要的吗?