如果我有一个我想要执行位操作的整数,我该如何将其加载到java.util.BitSet
?如何将其转换回int或long?我不太关心BitSet
的大小 - 它总是32或64位长。我只想使用set()
,clear()
,nextSetBit()
和nextClearBit()
方法而不是按位运算符,但我找不到一种简单的方法来初始化用数字类型设置位。
答案 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
,如果它不太可能是性能瓶颈 - 它有getLowestSetBit
,setBit
和{{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::valueOf
和BitSet::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)
方法不是您想要的吗?