使用Java BitSet 类实现位集合操作

一、BitSet 类概述

Java BitSet 类表示一组简单的开关或标志。它内部由一个长整型数组(long[])实现,其中每个元素都代表64位的二进制数,这些二进制数的每一位可看作一个开关,开关只有两种状态,即打开(1)和关闭(0)。可以通过调整这些开关的状态,来进行一些位运算操作。BitSet 类封装的是一组位,因此集合运算也可以被实现。该类是线程安全的。

二、BitSet 类的常用方法

1.void set(int index)

将指定的位设置为 true。index 参数表示要设置的位的索引(第一个位的索引是0),该方法不会返回任何值。

BitSet bitSet = new BitSet(8);
bitSet.set(0);
bitSet.set(2);
System.out.println(bitSet); // 输出{0, 2}

2.void clear(int index)

将指定的位设置为 false。index 参数表示要清除的位的索引(第一个位的索引是0),该方法不会返回任何值。

BitSet bitSet = new BitSet(8);
bitSet.set(0);
bitSet.set(2);
bitSet.clear(2);
System.out.println(bitSet); // 输出{0}

3.boolean get(int index)

返回指定位的值。index 参数表示要查询的位的索引(第一个位的索引是0),如果该位是开启的则返回 true,否则返回 false。

BitSet bitSet = new BitSet(8);
bitSet.set(0);
System.out.println(bitSet.get(0)); // 输出true

4.int nextClearBit(int fromIndex)

返回第一个未被设置为开启的位的索引(第一个位的索引是0),该索引的值大于或等于 fromIndex。如果不存在这样的索引,则返回 bitSet 的大小:length()

BitSet bitSet = new BitSet(8);
bitSet.set(0);
bitSet.set(3);
int index = bitSet.nextClearBit(0);
System.out.println(index); // 输出1

5.String toString()

将 BitSet 转换成 String 类型。该方法返回包含所有位状态的字符串。0 表示关闭状态,1 表示开启状态,左边的位是最高有效位。

BitSet bitSet = new BitSet(8);
bitSet.set(0);
bitSet.set(2);
System.out.println(bitSet.toString()); // 输出“00000101”

三、在实际应用中使用 BitSet 类

1. 应用场景1:少量整数的排序

如果需要对一个不大的整数集合进行排序,将集合中的每个值作为 BitSet 的索引,可以方便地进行排序。下面的示例中,我们将整数集合{1,3,5,7,9}排序:

BitSet bitSet = new BitSet();
int[] arr = {1,3,5,7,9};
for (int i : arr) {
    bitSet.set(i);
}
for (int i = 0; i < bitSet.size(); i++) {
    if (bitSet.get(i)) {
        System.out.print(i + " ");
    }
} // 输出“1 3 5 7 9”

2. 应用场景2:按位存储和传输数据

在某些情况下,需要按位存储和传输数据。应用 BitSet 类可以方便地进行这些操作。下面是一个示例,我们使用 BitSet 类按位存储和传输 5 个字节的数据,然后再将其转换回字节形式:

BitSet bitSet = new BitSet();
byte[] bytes = {0b00010011, 0b01010101, 0b10101010, (byte) 0b11001100, (byte) 0b11110000};
for (int i = 0; i < bytes.length; i++) {
    for (int j = 0; j < 8; j++) {
        int val = bytes[i] & (1 < 0) {
            bitSet.set(i * 8 + j);
        }
    }
}
System.out.println(bitSet); // 输出{0, 2, 4, 6, 8, 10, 12, 16, 18, 20, 22, 26, 27, 28, 29, 30}
byte[] newBytes = new byte[5];
for (int i = 0; i < bitSet.size(); i += 8) {
    byte b = 0;
    for (int j = 0; j < 8; j++) {
        if (bitSet.get(i + j)) {
            b |= 1 << j;
        }
    }
    newBytes[i / 8] = b;
}
System.out.println(Arrays.toString(newBytes)); // 输出“[19, 85, -86, -52, -16]”

3. 应用场景3:判断两个集合的交集和并集

使用 BitSet 类可以方便地实现位运算,进而实现原本需要较长的代码实现的集合操作。下面的示例中,我们新建两个 BitSet 类型的集合 bitSet1 和 bitSet2,其中 bitSet1 包含索引值为 1、3、5 和 7 的四个位,bitSet2 包含索引值为 3、4 和 5 的三个位。我们使用 and() 方法得到 bitSet1 和 bitSet2 的交集,使用 or() 方法得到 bitSet1 和 bitSet2 的并集:

BitSet bitSet1 = new BitSet();
BitSet bitSet2 = new BitSet();
bitSet1.set(1);
bitSet1.set(3);
bitSet1.set(5);
bitSet1.set(7);
bitSet2.set(3);
bitSet2.set(4);
bitSet2.set(5);
BitSet andBitSet = (BitSet) bitSet1.clone();
andBitSet.and(bitSet2);
System.out.println(andBitSet); // 输出{3, 5}
BitSet orBitSet = (BitSet) bitSet1.clone();
orBitSet.or(bitSet2);
System.out.println(orBitSet); // 输出{1, 3, 4, 5, 7}

四、总结

本文介绍了使用 Java BitSet 类实现位集合操作的概念和常用方法,并提供了三个常见的应用场景。通过对 BitSet 类的使用,我们可以更方便地进行位运算和集合运算。在实际应用中,需要根据实际需求选择合适的方法和算法。

原创文章,作者:小蓝,如若转载,请注明出处:https://www.506064.com/n/183100.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
小蓝小蓝
上一篇 2024-11-24 16:26
下一篇 2024-11-24 16:26

相关推荐

  • java client.getacsresponse 编译报错解决方法

    java client.getacsresponse 编译报错是Java编程过程中常见的错误,常见的原因是代码的语法错误、类库依赖问题和编译环境的配置问题。下面将从多个方面进行分析…

    编程 2025-04-29
  • Java JsonPath 效率优化指南

    本篇文章将深入探讨Java JsonPath的效率问题,并提供一些优化方案。 一、JsonPath 简介 JsonPath是一个可用于从JSON数据中获取信息的库。它提供了一种DS…

    编程 2025-04-29
  • Java Bean加载过程

    Java Bean加载过程涉及到类加载器、反射机制和Java虚拟机的执行过程。在本文中,将从这三个方面详细阐述Java Bean加载的过程。 一、类加载器 类加载器是Java虚拟机…

    编程 2025-04-29
  • Java腾讯云音视频对接

    本文旨在从多个方面详细阐述Java腾讯云音视频对接,提供完整的代码示例。 一、腾讯云音视频介绍 腾讯云音视频服务(Cloud Tencent Real-Time Communica…

    编程 2025-04-29
  • Java Milvus SearchParam withoutFields用法介绍

    本文将详细介绍Java Milvus SearchParam withoutFields的相关知识和用法。 一、什么是Java Milvus SearchParam without…

    编程 2025-04-29
  • Python栈操作用法介绍

    如果你是一位Python开发工程师,那么你必须掌握Python中的栈操作。在Python中,栈是一个容器,提供后进先出(LIFO)的原则。这篇文章将通过多个方面详细地阐述Pytho…

    编程 2025-04-29
  • Java 8中某一周的周一

    Java 8是Java语言中的一个版本,于2014年3月18日发布。本文将从多个方面对Java 8中某一周的周一进行详细的阐述。 一、数组处理 Java 8新特性之一是Stream…

    编程 2025-04-29
  • Java判断字符串是否存在多个

    本文将从以下几个方面详细阐述如何使用Java判断一个字符串中是否存在多个指定字符: 一、字符串遍历 字符串是Java编程中非常重要的一种数据类型。要判断字符串中是否存在多个指定字符…

    编程 2025-04-29
  • VSCode为什么无法运行Java

    解答:VSCode无法运行Java是因为默认情况下,VSCode并没有集成Java运行环境,需要手动添加Java运行环境或安装相关插件才能实现Java代码的编写、调试和运行。 一、…

    编程 2025-04-29
  • Java任务下发回滚系统的设计与实现

    本文将介绍一个Java任务下发回滚系统的设计与实现。该系统可以用于执行复杂的任务,包括可回滚的任务,及时恢复任务失败前的状态。系统使用Java语言进行开发,可以支持多种类型的任务。…

    编程 2025-04-29

发表回复

登录后才能评论