なぜこれを行うのかよくわかりませんが、方法を逆にしてみませんか?
private static BitSet toBitset(final char[] entries){
final int length = entries.length;
BitSet bs = new BitSet(length);
for(int i = 0; i < length; i++){
bs.set(i, entries[i] == '1');
}
return bs;
}
編集:メソッドを修正したかったようですので、char配列を特定のサイズに強制する方法は1つしか考えられませんが、最後に追加するゼロの数を知る必要があるため、書き直しましたこのようなあなたの方法:
private static char[] toCharArray(final BitSet bs, int expectedBits){
if(expectedBits < bs.length()){
expectedBits = bs.length();
}
final char[] arr = new char[expectedBits];
for(int i = 0; i < expectedBits; i++){
arr[i] = bs.get(i) ? '1' : '0';
}
return arr;
}
ビットマップの使用に関する問題は、「1」のみを格納するため、ビットセットの最後のエントリは常に「1」になり、長さは常にビットセットの最後の「1」を参照することです。
例えば:
BitSet bs = new BitSet();
for(int i = 0; i < 1000; i++){
bs.set(i, false);
}
System.out.println(bs.length());
「0」を出力しますが、
BitSet bs = new BitSet();
bs.set(10001, true);
System.out.println(bs.length());
10002を印刷します。
これはあなたを助けるかもしれません(しかしあなたはそれに応じて上記のメソッドを編集する必要があるでしょう):
class FixedBitSet extends BitSet {
private int maxLength = 0;
public int maxLength(){
return maxLength;
}
@Override
public void set(int bitIndex, boolean value) {
super.set(bitIndex, value);
if(bitIndex > maxLength){
maxLength = bitIndex;
}
}
}