Java.util包下BitSet的用法

    BitSet:是一个字节集合,用它能够表示整数和进行求两个集合的交集、并集等运算。java

    咱们知道,计算机存储的最小单位是比特bit,而咱们在java程序中的最小单位是字节Byte,他们之间的换算关系是1Byte=8bit。BitSet是根据比特所在的位置表示整形数据大小。例如:16在第16个位置,5在第5个位置,所以下面的BitSet能够表示集合{5,16}函数

    

    

    经过分析BitSet的源代码,咱们知道,BitSet提供两个构造函数,一个是BitSet(),不带参数,一个是BitSet(int nbits);若是咱们使用不带参数的构造函数建立BitSet对象,则建立一个默认长度为64比特bit的对象,这个对象能够表示的数据大小就是1~64,不过即便咱们放入大于64的数据也没有关系,由于BitSet是自增加的,最大值能够是Integer.MAX_VALUE=2147483647。spa

    知道了表示方法,对它的做用就不难理解了,比方说上面的集合与{2,23,48}求并集:则变成了比特码的或运算。对象

00000000 00000000 00000000 00000000 00000000 00000000 10000000 00100000    集合{5,16}内存

00000000 00000000 10000000 00000000 00000000 01000000 00000000 00000010    集合{2,23,48}it

或运算后的结果就是io

00000000 00000000 10000000 00000000 00000000 01000000 10000000 00100010,因此结果就是{2,5,16,23,48}thread

其它更大的数字无非就是比特码更长。构造函数

注意:程序

若是建立建立一个最大位数的BitSet集合BitSet bitSet = new BitSet(Integer.MAX_VALUE);

         会报以下错误

         Exception in thread "main" java.lang.OutOfMemoryError: Java heap space

   at java.util.BitSet.initWords(BitSet.java:144)

   at java.util.BitSet.<init>(BitSet.java:139)

   at Test.main(Test.java:10)

         这说明,java 堆heap内存不足,能够经过以下方式更改:

   

    其它报java.lang.OutOfMemoryError: Java heap space错误的时候也能够这样更改

相关文章
相关标签/搜索