Bag集合工具类(apache-commons-collections3.2工具包)在java中的使用

简介: Bag集合工具类(apache-commons-collections3.2工具包)在java中的使用 Bag 是在 org.apache.commons.collections 包中定义的接口 ,也是集合的一种扩充工具类,当然结合用JDK中的map类进行相应的逻辑处理,也能实现Bag类的功能,但apache推出来肯定有它的原因和用处,知道有这么一个类了解它大概的用法,开发的时候真遇到这种情况,知道有这么个工具在你身边等着你用呢。

Bag集合工具类(apache-commons-collections3.2工具包)在java中的使用

Bag 是在 org.apache.commons.collections 包中定义的接口 ,也是集合的一种扩充工具类,当然结合用JDK中的map类进行相应的逻辑处理,也能实现Bag类的功能,但apache推出来肯定有它的原因和用处,知道有这么一个类了解它大概的用法,开发的时候真遇到这种情况,知道有这么个工具在你身边等着你用呢。

此接口定义源码:

[java] view plain copy

  1. public interface Bag extends Collection {
  2.     /**
  3.      * Returns the number of occurrences (cardinality) of the given
  4.      * object currently in the bag. If the object does not exist in the
  5.      * bag, return 0.
  6.      * 
  7.      * @param object  the object to search for
  8.      * @return the number of occurrences of the object, zero if not found
  9.      */
  10.     int getCount(Object object);

[java] view plain copy

  1. }

 

它 继承了 java.util.Collection , 而它的实现类都被放在下面的bag 包中:

 Bag,"袋"的意思,肯定是装“东西”的,之所以有这样一组类型 , 是因为我们有时候需要在Collection 中存放多个相同对象的拷贝 , 并且需要很方便的取得该对象拷贝的个数 。 需要注意的一点是它虽然继承JDK中的Collection ,但是如果真把它完全当作java.util.Collection 来用会遇到语义上的问题,HashBag 是 Bag 接口的一个标准实现。而BagUtils 提供一组static 的方法让调用者获取经过不同装饰后的 Bag 实例。

看一下具体用法就一目了然了:

[java] view plain copy

 

定义一个简单辅助类:

[java] view plain copy

  1. package apache_commons_collections;
  2. public class Person {
  3.     public String name;
  4.     public int year;
  5.     public Person(){
  6.     }
  7.     public Person(String name,int year){
  8.         this.name=name;
  9.         this.year=year;
  10.     }
  11.     public String getName(){
  12.         return this.name;
  13.     }
  14.     public int getYear(){
  15.         return this.year;
  16.     }
  17. }

测试:

[java] view plain copy

  1. package apache_commons_collections;
  2. import org.apache.commons.collections.Bag;
  3. import org.apache.commons.collections.BagUtils;
  4. import org.apache.commons.collections.bag.HashBag;
  5. public class BagTest {
  6.     public static void main(String args[]){
  7.         Person p1=new Person("chen",23);
  8.         Person p2=new Person("chen",21);
  9.         Person p3=new Person("chen",11);
  10.         Bag myBag=BagUtils.typedBag(new HashBag(),Person.class);    //实例化一个Bag
  11.         myBag.add(p1,11);
  12.         myBag.add(p2,143);
  13.         myBag.add(p3,67);
  14.         System.out.println(myBag.getCount(p1));
  15.         System.out.println(myBag.getCount(p2));
  16.         System.out.println(myBag.getCount(p3));
  17.     }
  18. }

 

结果:

[java] view plain copy

  1. 11
  2. 143
  3. 67

更加详细的用法和说明,大家可以http://commons.apache.org/proper/commons-collections/下载源码和相应的API文档仔细研究研究。

注意:这组接口违反了 Collection contract。这些方法中指定的行为不一样所指定的行为集合。不合规的方法显然是标有“(违反)”。使用这个Bag保持谨慎。
这违反了从原始规范的接口。在一个理想世界中,接口将改变解决此问题,但是已经决定维持向后兼容性。


原文地址http://www.bieryun.com/2228.html

相关文章
|
15天前
|
存储 缓存 安全
Java 集合江湖:底层数据结构的大揭秘!
小米是一位热爱技术分享的程序员,本文详细解析了Java面试中常见的List、Set、Map的区别。不仅介绍了它们的基本特性和实现类,还深入探讨了各自的使用场景和面试技巧,帮助读者更好地理解和应对相关问题。
36 5
|
28天前
|
存储 缓存 安全
Java 集合框架优化:从基础到高级应用
《Java集合框架优化:从基础到高级应用》深入解析Java集合框架的核心原理与优化技巧,涵盖列表、集合、映射等常用数据结构,结合实际案例,指导开发者高效使用和优化Java集合。
40 4
|
1月前
|
Java
Java 8 引入的 Streams 功能强大,提供了一种简洁高效的处理数据集合的方式
Java 8 引入的 Streams 功能强大,提供了一种简洁高效的处理数据集合的方式。本文介绍了 Streams 的基本概念和使用方法,包括创建 Streams、中间操作和终端操作,并通过多个案例详细解析了过滤、映射、归并、排序、分组和并行处理等操作,帮助读者更好地理解和掌握这一重要特性。
35 2
|
1月前
|
存储 Java
判断一个元素是否在 Java 中的 Set 集合中
【10月更文挑战第30天】使用`contains()`方法可以方便快捷地判断一个元素是否在Java中的`Set`集合中,但对于自定义对象,需要注意重写`equals()`方法以确保正确的判断结果,同时根据具体的性能需求选择合适的`Set`实现类。
|
1月前
|
安全 Java
Java多线程集合类
本文介绍了Java中线程安全的问题及解决方案。通过示例代码展示了使用`CopyOnWriteArrayList`、`CopyOnWriteArraySet`和`ConcurrentHashMap`来解决多线程环境下集合操作的线程安全问题。这些类通过不同的机制确保了线程安全,提高了并发性能。
|
1月前
|
存储 Java 开发者
在 Java 中,如何遍历一个 Set 集合?
【10月更文挑战第30天】开发者可以根据具体的需求和代码风格选择合适的遍历方式。增强for循环简洁直观,适用于大多数简单的遍历场景;迭代器则更加灵活,可在遍历过程中进行更多复杂的操作;而Lambda表达式和`forEach`方法则提供了一种更简洁的函数式编程风格的遍历方式。
|
1月前
|
存储 Java 开发者
Java中的集合框架深入解析
【10月更文挑战第32天】本文旨在为读者揭开Java集合框架的神秘面纱,通过深入浅出的方式介绍其内部结构与运作机制。我们将从集合框架的设计哲学出发,探讨其如何影响我们的编程实践,并配以代码示例,展示如何在真实场景中应用这些知识。无论你是Java新手还是资深开发者,这篇文章都将为你提供新的视角和实用技巧。
34 0
|
15天前
|
存储 人工智能 大数据
The Past, Present and Future of Apache Flink
本文整理自阿里云开源大数据负责人王峰(莫问)在 Flink Forward Asia 2024 上海站主论坛开场的分享,今年正值 Flink 开源项目诞生的第 10 周年,借此时机,王峰回顾了 Flink 在过去 10 年的发展历程以及 Flink社区当前最新的技术成果,最后展望下一个十年 Flink 路向何方。
301 33
The Past, Present and Future of Apache Flink
|
2月前
|
SQL Java API
Apache Flink 2.0-preview released
Apache Flink 社区正积极筹备 Flink 2.0 的发布,这是自 Flink 1.0 发布以来的首个重大更新。Flink 2.0 将引入多项激动人心的功能和改进,包括存算分离状态管理、物化表、批作业自适应执行等,同时也包含了一些不兼容的变更。目前提供的预览版旨在让用户提前尝试新功能并收集反馈,但不建议在生产环境中使用。
859 13
Apache Flink 2.0-preview released
|
2月前
|
存储 缓存 算法
分布式锁服务深度解析:以Apache Flink的Checkpointing机制为例
【10月更文挑战第7天】在分布式系统中,多个进程或节点可能需要同时访问和操作共享资源。为了确保数据的一致性和系统的稳定性,我们需要一种机制来协调这些进程或节点的访问,避免并发冲突和竞态条件。分布式锁服务正是为此而生的一种解决方案。它通过在网络环境中实现锁机制,确保同一时间只有一个进程或节点能够访问和操作共享资源。
101 3

推荐镜像

更多