在commons-collections中为我们提供了一些关于集合的实现,今天为大家介绍一下<code>bag</code>相关类的用法。
<code>bag</code>继承自<code>collection</code>接口,定义了一个集合,该集合会记录对象在集合中出现的次数。
假设你有一个包,包含{a, a, b, c}。调用getcount(a)方法将返回2,调用uniqueset()方法将返回{a, b, c}。
返回值
方法名
说明
boolean
add(object object)
(违反)将指定的对象添加到该包中
add(object object, int ncopies)
将指定数量的对象添加到该包中
containsall(collection coll)
判断包中是否含有集合中所有元素
int
getcount(object object)
获得对象在包中的数量
iterator
iterator()
获得包元素迭代器
remove(object object)
移除包中元素
remove(object object, int ncopies)
移除指定数量的包中的元素
removeall(collection coll)
移除包中包含的集合中的所有元素
retainall(collection coll)
删除包中不在集合中的元素
size()
获得包中元素个数
set
uniqueset()
获得包中唯一元素集合(去重)
<code>hashbag</code>使用<code>hashmap</code>作为数据存储,是一个标准的<code>bag</code>实现。
使用示例:
运行结果:
<code>包中元素为: s1 s1 s2 s2 s2 包中元素个数为:5 包中entity1个数为:2 去重后个数为:2</code>
<code>treebag</code>使用<code>treemap</code>作为数据存储,用法与<code>hashbag</code>类似,只是<code>treebag</code>会使用自然顺序对元素进行排序。
<code>包中元素为: s1 s2 s3 包中元素个数为:3 包中entity1个数为:1 去重后个数为:3</code>
关于bag的更多内容,可以去官网查看相关的帮助文档。