Java Bitset
Bitset创建一种特殊的数组来保存非负整数的值
取值为true和false,初始都是false。Bitset初始化是一个long,65位,增加位数的话只能是64的整数倍。
如果用一个Bitset存储一组数组【2,4,6,8】,将会是这样的:
找出最大值8,给其加1=9
声明一个Bitset bs[9]
bs[9]=[0,0,1,0,1,0,1,0,1]//数组从第0位到第8位分别代表的是0,1,2,3,4,5,6,7,8,所以bs数组里为1 的就代表有值,为0的就代表没有值
0是false,1是true。
查看BitSet初始化值的代码
package study.stage1;
import java.util.BitSet; /**
* Created by Sandy.Liu on 2017/7/11.
*/
public class BitsetTest {
public static void main(String[] args){
BitSet bs1 = new BitSet();
System.out.println("is bs1 empty: "+bs1.isEmpty()+ " bs1.size: "+bs1.size());
bs1.set(1);
System.out.println("is bs1 empty: "+bs1.isEmpty()+ " bs1.size: "+bs1.size());
bs1.set(65);
System.out.println("is bs1 empty: "+bs1.isEmpty()+ " bs1.size: "+bs1.size()); }
} 运行结果
is bs1 empty: true bs1.size: 64
is bs1 empty: false bs1.size: 64
is bs1 empty: false bs1.size: 128
实例2:void and (BitSet set)
package study.stage1;
import java.util.BitSet; /**
* Created by Sandy.Liu on 2017/7/11.
*/
public class BitSetTest1 {
public static void main(String[] args){
//初始化两个Bitset
BitSet bs1 = new BitSet();
BitSet bs2 = new BitSet();
//给两个bitset赋值
for(int i = 0;i<30;i++){
if(i%2==0){
bs1.set(i);
}
if(i%5==0){
bs2.set(i);
}
}
System.out.println("bs1: "+bs1);
System.out.println("bs2: "+bs2); //bs1 and bs2,值存储在bs1中
bs1.and(bs2);
System.out.println("bs1 and bs2: "+bs1); }
}
运行结果:
bs1: {0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28}
bs2: {0, 5, 10, 15, 20, 25}
bs1 and bs2: {0, 10, 20}
分析:
bs1[10101010101010101010101010101]
bs2[100001000010000000001]
所以bs1 and bs2后的值为:【100000000010000000001】,所以就是{0,10,20}
存储的时候会对重复的数字过滤,重复的数字只记一次。
BitSet中实现了Cloneable中的方法如下:
1. void and(BitSet set) 对此目标位和参数位set执行逻辑与操作
2. void andNot(BitSet bet) :
bs1.andNot(bs2) 清除bs1当中存在于bs2中的位。
bs2: {0, 2, 4, 6, 8, 10, 12, 14, 16, 18, 20, 22, 24, 26, 28}
bs1: {0, 5, 10, 15, 20, 25}
bs1.andNot(bs2): {5,15,25}
3. int cardinality() 返回此BitSet中设置我true的位数
bs1: {0, 5, 10, 15, 20, 25}
bs1.cardinality(): 6
4. void clear() 将所有的位设置为false
5 void clear(int index) 将索引指定的位设置为false
6. void clear(int startIndex, int endIndex) 将startIndex(包括)到endIndex(不包括)之间的位设置为false
7. object clone()复制此BitSet,生成一个相等的新的BitSet。需要注意的是新的BitSet是object类型,赋值给BitSet类型需要强制类型转换
bs1: {0, 5, 10, 15, 20, 25}
bs2
bs2 = (BitSet)bs1.clone();
8. boolean equals(object Bitset) 与指定的对象进行比较
9. boolean getIndex(int index) 返回指定位置处的位值
bs1.getIndex(5): true
10. BitSet get(int startIndex, int endIndex)
返回一个新的 BitSet,它由此 BitSet 中从 fromIndex(包括)到 toIndex(不包括)范围内的位组成。
11. int hashCode( )
返回此位 set 的哈希码值。
12. boolean isEmpty( )
如果此 BitSet 中没有包含任何设置为 true 的位,则返回 ture。
13. int length( )
返回此 BitSet 的"逻辑大小":BitSet 中最高设置位的索引加 1。
bs1: {0, 5, 10, 15, 20, 25}
bs2.length(): 26
14. int size( )
返回此 BitSet 表示位值时实际使用空间的位数。
bs1: {0, 5, 10, 15, 20, 25}
bs2.size(): 64
Java Bitset的更多相关文章
- Java BitSet解决海量数据去重
先提一个问题,怎么在40亿个整数中找到那个唯一重复的数字? 第一想法就是Set的不可重复性,依次把每个数字放入HashSet中,当放不去进去的时候说明这就是重复的数字,输出这个数字. if(hs.co ...
- java bitSet简单使用
package Contain; import java.util.BitSet; public class MyBitset { public static void main(String[] a ...
- Java BitSet使用场景和示例
一.什么是BitSet? 注:以下内容来自JDK API: BitSet类实现了一个按需增长的位向量.位Set的每一个组件都有一个boolean值.用非负的整数将BitSet的位编入索引.可以对每个编 ...
- 位集合(BitSet)| Java数据结构
Java Bitset类 BitSet使用示例: import java.util.BitSet; public class BitSetDemo { public static void main( ...
- (私人收藏)[开发必备]最全Java离线快速查找手册(可查询可学习,带实例)
(私人收藏)[开发必备]最全Java离线快速查找手册(可查询可学习,带实例) https://pan.baidu.com/s/1L54VuFwCdKVnQGVc8vD1TQnwmj java手册 Ja ...
- 日常Java 2021/10/14
Java数据结构 Java BitSet类 BitSet类创建一种特殊类型的数组来保存位值,数组大小随需要增加,BitSet(),BitSet(int size) 其中的方法 void and(Bit ...
- 日期的压缩存储daybits
问题: 存储一个日期的序列,例如保存用户一年的登录时间序列,20140201,20130102这样两个日期,如果用INT那么需要八个字节,用STRING就更多了. 解决: 通过bit来存储一天,具体的 ...
- JavaBitSet学习
一.背景 之前公司项目需要对会员人群进行去重过滤,人群的维度是user_id: 因此采用了BitSet做简单的去重,方案将user_id作为bitset中的bit索引: 通过and\or\xor基础运 ...
- 20180824-Java Enumeration 接口
Java Enumeration接口 Enumeration接口中定义了一些方法,通过这些方法可以枚举(一次获得一个)对象集合中的元素. 这种传统接口已被迭代器取代,虽然Enumeration 还未被 ...
随机推荐
- springboot学习章节代码-spring基础
1.DI package com.zhen.highlights_spring4.ch1.di; import org.springframework.stereotype.Service; /** ...
- SharePoint online Multilingual support - Settings
博客地址:http://blog.csdn.net/FoxDave This post will talk about how to enable sharepoint online site mul ...
- uniDAC 7.2.14直联sqlite存在问题
用最新的uniDAC 7.2.14,设置Direct=True,直联sqlite数据库,发现Release状态下出错,Debug没有问题. 改成Direct=False,则没有问题. 警告! 各 ...
- 阻止ARP欺骗
利用Look N Stop防火墙,防止arp欺骗 阻止网络执法官控制 网络执法官是利用的ARp欺骗的来达到控制目的的. ARP协议用来解析IP与MAC的对应关系,所以用下列方法可以实现抗拒网络执法官的 ...
- 利用python将数据转存入sqlite3
案例的目标是将存在文件中的json格式数据转存到sqlite数据库中.因此,需要利用python逐行读取json文件中数据,对数据进行解析和入库.具体操作步骤如下: 1.逐行读取json文件 for ...
- js第一天学习内容
var a=12: var t=(- -a)-(a- -)+(a++)-(a++) console.log(a) t=-1: a=12: (- -a)=11-(a=11- -)=10+(a=10++) ...
- Bug03_SSM整合_mybatis result maps collection already contains value...
这个问题是在映射文件,但是这个映射文件是自动生成的. 所以想起来可能是在自动生成映射文件,pojo类时操作有问题.第一次运行时,出现错误,没有删除已经生成的文件就直接运行了第二次. 解决办法:删除旧的 ...
- python2和Python3的区别(长期更新)
1.在Python2中无需将打印的内容放在括号内,但是Python3中必须将打印的内容放在括号内,从技术上看Python3中的print是函数. 2.对于用户交互终点额输入input,在python2 ...
- 2018上C语言程序设计(高级)作业- 第3次作业
作业要求一 6-1 输出月份英文名 6-2 查找星期 6-3 计算最长的字符串长度 6-4指定位置输出字符串 6-5奇数值结点链表 6-6学生成绩链表处理 6-7链表拼接 作业要求二 题目6-1输出月 ...
- mastering elasticsearch
概念: Term: 它是搜索的基本单位,其表现形式为文本中的一个词. Token: 它是单个Term在所属Field中文本的呈现形式,包含了Term内容.Term类型.Term在文本中的起始及偏移位置 ...