将byte或int转换为bitset

时间:2012-08-05 21:59:09

标签: java type-conversion bitarray

我有以下内容:

int num=Integer.parseInt(lineArray[0]);
byte numBit= num & 0xFF;

有没有非常简单的方法将numBit转换为位数组?或者更好的是,有没有办法绕过int的字节转换并从num直接到位数组?

由于

5 个答案:

答案 0 :(得分:10)

如果您想要BitSet,请尝试:

final byte b = ...;
final BitSet set = BitSet.valueOf(new byte[] { b });

如果您想要boolean[]

static boolean[] bits(byte b) {
  int n = 8;
  final boolean[] set = new boolean[n];
  while (--n >= 0) {
    set[n] = (b & 0x80) != 0;
    b <<= 1;
  }
  return set;
}

或等同地

static boolean[] bits(final byte b) {
  return new boolean[] {
    (b &    1) != 0,
    (b &    2) != 0,
    (b &    4) != 0,
    (b &    8) != 0,
    (b & 0x10) != 0,
    (b & 0x20) != 0,
    (b & 0x40) != 0,
    (b & 0x80) != 0
  };
}

答案 1 :(得分:2)

Java 7有BitSet.valueOf(long [])和BitSet.toLongArray()

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

答案 2 :(得分:1)

你可以这样做:

char[] bits = Integer.toBinaryString(num).toCharArray();将基础位字符串作为char[]

E.g。

public BitSet getBitSet(int num){
    char[] bits = Integer.toBinaryString(num).toCharArray();  
    BitSet bitSet = new BitSet(bits.length);  
    for(int i = 0; i < bits.length; i++){  
        if(bits[i] == '1'){
            bitSet.set(i, true);
        }
        else{
            bitSet.set(i, false);
        }                
    }
    return bitSet;
}  

您也可以通过这种方式创建boolean []数组。

答案 3 :(得分:0)

我发现了这个帖子,因为Android在API 19中添加了BitSet.valueOf()。 我使用了oldrinb的第二段接受答案,但由于它有一些错误而不得不修改它。另外我修改它以返回一个BitSet,但将它更改为boolean []不应该是一个问题。请参阅我对他的回复的评论。

这是现在成功运行的修改:

public static BitSet toBitSet(byte b) {
    int n = 8;
    final BitSet set = new BitSet(n);
    while (n-- > 0) {
        boolean isSet = (b & 0x80) != 0;
        set.set(n, isSet);
        b <<= 1;
    }
    return set;
}

答案 4 :(得分:0)

只是使用溪流(J8 +)的练习:

// J7+
BitSet bitSet(final long... nums) {
    return BitSet.valueOf(nums);
}

// J8+
final IntStream bitsSet = bitSet(num).stream();

// vice-versa
BitSet bitSet(final IntStream bitsSet) {
    return bitsSet.collect(BitSet::new, BitSet::set, BitSet::or);
}

// without BitSet
IntStream bitsSet(final long... nums) {
    return IntStream.range(0, nums.length)
            .flatMap(n -> IntStream.range(0, Long.SIZE - 1)
                    .filter(i -> 0 != (nums[n] & 1L << i))
                    .map(i -> i + n * Long.SIZE));
}