Collection类适配器

本文深入解析Java Collection框架的核心组件,包括Collection接口、AbstractCollection抽象类及其实现机制,并探讨了Iterator迭代器的重要作用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在开始整理Collection集合框架时,最应该了解的是几个抽象类:AbstractCollecton、AbstractList、AbstractSet和AbstractQueue等接口适配器类。在设计模式一书中有提到适配器模式,它包含三种形式:接口适配器、类适配器和对象适配器,而类适配器在java.util包的Collection中得到应用,作为Collection集合接口的抽象实现进行集中管理和封装共性。

Collection接口

这里写图片描述
从图中可以看出,Collection结构规定了聚合对象必须包含14个基本功能,其中size、contains、add和remove说明了数据结构中的大小、增加、删除和查找基本功能,而toArray和retainAll、isEmpty和clear都是在上面的四个基本功能上的扩展。此外,Iterable接口也说明了Collection对象可以使用foreach进行遍历。

AbstractCollection

先来看下它的源码定义

package java.util;
public abstract class AbstractCollection
    implements Collection {
    protected AbstractCollection() {
    }

    public abstract Iterator iterator();
    public abstract int size();
    public boolean add(Object obj) {
        throw new UnsupportedOperationException();
    }
    //具体实现方法... ... 
} 

只有iterator、size和add需要AbstractCollection子类进行实现,采用类适配器可以有效的较少系统代码规模、降低代码的维护成本。此外,抽象父类和接口适配的模式可以强迫子类实现未在Abstract中实现接口功能。从源码中可以看到,addAll、remove和contains等方法都依赖于iterator功能。

Iterator

迭代器在Collection中至关重要,它起到对聚合对象的有序访问功能。Collection中提供iterator工厂方法生成Iterator实例。迭代器本身包含的功能如下:

package java.util;
public interface Iterator {
    boolean hasNext();
    Object next();
    void remove();
}

也就是说Collection内部依赖的Iterato必须实现通过hashNext检查是否存在元素,next获取元素和remove删除当前元素的功能。

结论

Collection接口的适配器类AbstractCollection及其子接口List、Set、Queue的适配器类AbstractList、AbstractSet和AbstractQueue的原理相同,通过抽象类来实现接口,将子类实现中的公共方法交予抽象父类实现,减少系统复杂度,降低代码的维护成本。此外,由Iterator迭代器来实现对聚合Collection对象的有序访问,将复杂的对象访问控制封装与Iterator实现类中,也减少系统复杂度,降低代码的维护成本。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值