Java 中 BitSet 类的用法

API

构造

  1. 无参构造 :默认为 64 个 bit 的容量
	BitSet bitset = new BitSet();
  1. 有参构造 :设置为 n 个 bit 的容量
	BitSet bitset = new BitSet(1024);
  1. 静态工厂的 valueOf 构造 :支持从 byte[], long[], ByteBuffer, LongBuffer 四种类型构造 Bitset
   BitSet.valueOf(bytes);
   BitSet.valueOf(longs);
   BitSet.valueOf(byteBuffer);
   BitSet.valueOf(longBuffer);

置位为 true

  1. 单独置位
	bitset.set(4);//索引为4的位置的比特被置为1,返回void
  1. 批量置位
	bitset.set(4,6);//索引在[4,6)范围内的位置的比特被置为1,返回void

清除为 false

  1. 单独清除
	bitset.clear(4);//索引为4的位置的比特被置为0,返回void
  1. 批量清除
	bitset.clear(4,6);//索引在[4,6)范围内的位置的比特被置为0,返回void
  1. 全部清除
	bitset.clear();//所有位置都被清空为0,返回void

查找

  1. 查询某一位是否已被置位
	bitset.get(4);//返回boolean,为true表示该位被置位
  1. 获取某区间的 BitSet
	bitset.get(4,6);//返回另一个 BitSet,内容取 bitset的[4,6)之间的元素

注:获取的区间后,索引的编号会改变,比如这里新的 BitSet 的 0 号索引对应的是原来 BitSet 的 4 号索引

位反转

	bitset.flip(4);
	bitset.flip(4,6);

长度

有三个和长度相关的 API,分别是 size、cardinal、length

  1. size:返回该 BitSet 的最大容量
  2. cardinal:返回该 BitSet 中 1 的个数
  3. length:返回最后一个1之前的所有元素的个数,如果一个1也没有就返回0

运算

  1. 判断是否有交集
	first.intersects(second);//返回boolean,如果有交集元素则为true
  1. 求交集
	first.and(second);//返回一个 BitSet
  1. 求并集
	first.or(second);//返回一个 BitSet
  1. 求异或集
	first.xor(second);//返回一个 BitSet

	bitSet.stream();//返回一个 Stream 流

其他

下面四个方法顾名思义:

	 int idx = bitset.nextSetBit(fromIndex);
	 int idx = bitset.previousSetBit(fromIndex); 
	 int idx = bitset.nextClearBit(fromIndex);
	 int idx = bitset.previousClearBit(fromIndex); 

原理

底层数据结构

BitSet 的底层数据结构是 long[] 数组

如何工作

置位时,把1左移对应的位数,再与 long[] 中特定的 long 元素做或运算
查询时,把1左移对应的位数,再与 long[] 中特定的 long 元素做与运算,运算结果大于0说明该位为true

  • 5
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值