Java集合-Collection

简介: Java集合-Collection

40b246343339ac8c8b317e5649bc05ff.jpgCollection接口 (java.util.Collection) 是java集合根接口中的一个,尽管不直接实例化Collection,但是我们经常用到其子类,而且通常把其子类当做Collection使用,本文我们会讲到。


创建Collection

正如上面所说,我们不直接实例化Collection,而是实例化其子类,下面是创建Collection子类List的代码:


Collection collection = new ArrayList();

上面的示例适用于Collection的每个子类型。


Collection子类

Collection的子类接口:

  • List
  • Set
  • SortedSet
  • NavigableSet
  • Queue
  • Deque

Java没有提供Collection接口的可用实现,因此必须使用列出的子类型之一。Collection接口仅仅定义了一组所有子类都共享的方法,你可以忽略它的特定类型,把它当作一个Collection来处理。这是标准的继承,所以没有什么神奇之处,但是它仍然可以是一个很好的特性,下文会讲述这些共同的操作。

下面的代码是使用Collection的一个方法:

public class MyCollectionUtil{
  public static void doSomething(Collection collection) {
    Iterator iterator = collection.iterator();
    while(iterator.hasNext()){
      Object object = iterator.next();
      //do something to object here...
    }
  }
}

下面是几种不同的Collection子类调用上面的方法:

Set  set = new HashSet();
List list = new ArrayList();
MyCollectionUtil.doSomething(set);
MyCollectionUtil.doSomething(list);


Collection增加元素

无论使用Collection的哪个子类,都有标准的增加元素的方法,通过Collection的add()方法增加元素,下面是代码:

String     anElement  = "an element";
Collection collection = new HashSet();
boolean didCollectionChange = collection.add(anElement);

add()方法增加指定的元素,如果Collection因调用add()方法而更改,则返回true。如果Set中已经包含了此元素,那么就不再增加,另一方面,如果是List,则List中会存在两个同样的元素。


Collection移除元素

remove()方法用于移除指定的元素,如果元素在Collection则会返回true,如果不存在则会返回false,下面是代码:

boolean wasElementRemoved = collection.remove("an element");


Collection增加另外一个Collection

同样可以用Collection的addAll()方法增加另外一个Collection,下面是代码:

Set  aSet  = ... // get Set  with elements from somewhere
Collection collection = new HashSet();
collection.addAll(aSet);    //returns boolean too, but ignored here

Collection 的ddAll()方法增加参数Collection中的所有元素,但是增加的不是Collection本身仅仅是其元元素,如果使用Collection作为参数调用add(),则集合对象本身将被添加,而不是其元素。addAll()方法的具体行为取决于Collection子类型。某些Collection子类型允许将同一元素多次添加,而其他子类型则不允许。

Collection移除Collection
Collection的removeAll()移除给定参数Collection中的所有元素,如果参数Collection中的元素在本身Collection中不存在,则仅仅是忽略,下面是代码:
Collection objects = //... get a collection of objects from somewhere.
collection.removeAll(objects);


保留给定的Collection中的元素

Collection 的retainAll()方法刚好和 removeAll()方法相反,不是移除所有给定参数中的Collection元素,而是保留这些元素,移除其他的元素,需要注意的是仅仅保留原Collection中存在的元素。任何在参数中存在而原Collection中不存在的元素,会被忽略,不会被增加,下面代码:

Collection colA = new ArrayList();
Collection colB = new ArrayList();
colA.add("A");
colA.add("B");
colA.add("C");
colB.add("1");
colB.add("2");
colB.add("3");
Collection target = new HashSet();
target.addAll(colA);     //target now contains [A,B,C]
target.addAll(colB);     //target now contains [A,B,C,1,2,3]
target.retainAll(colB);  //target now contains [1,2,3]


检查Collection是否包含确定的元素

Collection有两个方法可以检查是否包含某个或者某些确定的元素, contains()和 containsAll()方法,下面是代码:

Collection collection = new HashSet();
boolean containsElement = collection.contains("an element");
Collection elements = new HashSet();
boolean containsAll = collection.containsAll(elements);

如果Collection中包含某个元素contains() 方法会返回true,否则会返回false。

如果Collection中包含给定Collection的所有元素,那么containsAll()返回true,否则返回false。


Collection大小

可以调用Collection的size()方法,返回Collection中的元素个数,下面代码:

int numberOfElements = collection.size();


迭代Collection

可以通过Iterator迭代Collection中的所有元素,下面是代码:

Collection collection = new HashSet();
//... add elements to the collection
Iterator iterator = collection.iterator();
while(iterator.hasNext()){
    Object object = iterator.next();
    System.out.println(object);
}

同样可以通过for-each循环迭代Collection:

Collection collection = new HashSet();
collection.add("A");
collection.add("B");
collection.add("C");
for(Object object : collection) {
    System.out.println(object);
}


目录
相关文章
|
2月前
|
安全 架构师 Java
Java大厂面试高频:Collection 和 Collections 到底咋回答?
Java中的`Collection`和`Collections`是两个容易混淆的概念。`Collection`是集合框架的根接口,定义了集合的基本操作方法,如添加、删除等;而`Collections`是一个工具类,提供了操作集合的静态方法,如排序、查找、同步化等。简单来说,`Collection`关注数据结构,`Collections`则提供功能增强。通过小王的面试经历,我们可以更好地理解这两者的区别及其在实际开发中的应用。希望这篇文章能帮助你掌握这个经典面试题。
53 4
|
3月前
|
存储 安全 Java
Java 集合框架中的老炮与新秀:HashTable 和 HashMap 谁更胜一筹?
嗨,大家好,我是技术伙伴小米。今天通过讲故事的方式,详细介绍 Java 中 HashMap 和 HashTable 的区别。从版本、线程安全、null 值支持、性能及迭代器行为等方面对比,帮助你轻松应对面试中的经典问题。HashMap 更高效灵活,适合单线程或需手动处理线程安全的场景;HashTable 较古老,线程安全但性能不佳。现代项目推荐使用 ConcurrentHashMap。关注我的公众号“软件求生”,获取更多技术干货!
57 3
|
5月前
|
算法 Java 数据处理
从HashSet到TreeSet,Java集合框架中的Set接口及其实现类以其“不重复性”要求,彻底改变了处理唯一性数据的方式。
从HashSet到TreeSet,Java集合框架中的Set接口及其实现类以其“不重复性”要求,彻底改变了处理唯一性数据的方式。HashSet基于哈希表实现,提供高效的元素操作;TreeSet则通过红黑树实现元素的自然排序,适合需要有序访问的场景。本文通过示例代码详细介绍了两者的特性和应用场景。
75 6
|
5月前
|
存储 Java
深入探讨了Java集合框架中的HashSet和TreeSet,解析了两者在元素存储上的无序与有序特性。
【10月更文挑战第16天】本文深入探讨了Java集合框架中的HashSet和TreeSet,解析了两者在元素存储上的无序与有序特性。HashSet基于哈希表实现,添加元素时根据哈希值分布,遍历时顺序不可预测;而TreeSet利用红黑树结构,按自然顺序或自定义顺序存储元素,确保遍历时有序输出。文章还提供了示例代码,帮助读者更好地理解这两种集合类型的使用场景和内部机制。
64 3
|
5月前
|
存储 Java 数据处理
Java Set接口凭借其独特的“不重复”特性,在集合框架中占据重要地位
【10月更文挑战第16天】Java Set接口凭借其独特的“不重复”特性,在集合框架中占据重要地位。本文通过快速去重和高效查找两个案例,展示了Set如何简化数据处理流程,提升代码效率。使用HashSet可轻松实现数据去重,而contains方法则提供了快速查找的功能,彰显了Set在处理大量数据时的优势。
59 2
|
3月前
|
存储 缓存 安全
Java 集合江湖:底层数据结构的大揭秘!
小米是一位热爱技术分享的程序员,本文详细解析了Java面试中常见的List、Set、Map的区别。不仅介绍了它们的基本特性和实现类,还深入探讨了各自的使用场景和面试技巧,帮助读者更好地理解和应对相关问题。
66 5
|
4月前
|
存储 缓存 安全
Java 集合框架优化:从基础到高级应用
《Java集合框架优化:从基础到高级应用》深入解析Java集合框架的核心原理与优化技巧,涵盖列表、集合、映射等常用数据结构,结合实际案例,指导开发者高效使用和优化Java集合。
82 4
|
4月前
|
存储 Java 开发者
在 Java 中,如何遍历一个 Set 集合?
【10月更文挑战第30天】开发者可以根据具体的需求和代码风格选择合适的遍历方式。增强for循环简洁直观,适用于大多数简单的遍历场景;迭代器则更加灵活,可在遍历过程中进行更多复杂的操作;而Lambda表达式和`forEach`方法则提供了一种更简洁的函数式编程风格的遍历方式。
|
4月前
|
Java
Java 8 引入的 Streams 功能强大,提供了一种简洁高效的处理数据集合的方式
Java 8 引入的 Streams 功能强大,提供了一种简洁高效的处理数据集合的方式。本文介绍了 Streams 的基本概念和使用方法,包括创建 Streams、中间操作和终端操作,并通过多个案例详细解析了过滤、映射、归并、排序、分组和并行处理等操作,帮助读者更好地理解和掌握这一重要特性。
67 2
|
4月前
|
存储 Java
判断一个元素是否在 Java 中的 Set 集合中
【10月更文挑战第30天】使用`contains()`方法可以方便快捷地判断一个元素是否在Java中的`Set`集合中,但对于自定义对象,需要注意重写`equals()`方法以确保正确的判断结果,同时根据具体的性能需求选择合适的`Set`实现类。

热门文章

最新文章