Java集合框架(一) 集合概述

本文详细介绍了Java集合框架,包括集合的作用、优点,以及Collection接口、List、Set和Map接口的实现类。此外,还阐述了Collection接口的重要方法,如添加、删除、遍历元素,并解释了迭代器在集合遍历中的作用。最后,讨论了equals方法在集合比较中的应用和注意事项。
摘要由CSDN通过智能技术生成

1.Java集合框架概述

作用:
就像一个容器,更方便的对多个对象进行存储和操作。 为了解决数组存储多个对象的弊端。

相比数组优点?
可以存储数量不等的多个对象,还可以存储具有映射关系的关联数组(map)。

数组的缺点:

  • 初始化之后,长度确定;长度不可变导致不便于扩展;
  • 声明的类型决定了数组元素初始化时的类型;
  • 提供的属性和方法少,不便于进行添加、删除、插入等操作,而且效率不高。也无法直接获取存储元素的个数
  • 存储的数据是有序的、可以重复的。 存储数据的特点单一。

2.Collection接口

接口继承树:实线 - 继承关系;虚线 - 实现关系。
在这里插入图片描述
在这里插入图片描述
Collection接口:单列集合,用来存储单个的对象;

  • List接口:存储有序的,可重复的数据。 “动态”数组
    • 实现类:ArrayList、LinkedList、Vector
  • Set接口:存储无需的,不可重复的数据。 对应高中数学中的集合
    • 实现类:HashSet、LinkedHashSet、TreeSet


Map接口:双列集合(映射),用来存储一对(key-value)数据

  • 实现类:HashMap、LinkedHashMap、TreeMap、Hashtable、Properties

3.Collection接口方法

  • Collection 接口是 List、Set 和 Queue 接口的父接口,该接口里定义的方法既可用于操作 Set 集合,也可用于操作
    List 和 Queue 集合。
  • JDK不提供此接口的任何直接实现,而是提供更具体的子接口(如:Set和List)实现。
    1、添加
add(Object obj)
addAll(Collection coll)

2、获取有效元素的个数

int size()

3、清空集合

void clear()

4、是否是空集合

boolean isEmpty()

5、是否包含某个元素

boolean contains(Object obj):是通过元素的equals方法来判断是否是同一个对象
boolean containsAll(Collection c):也是调用元素的equals方法来比较的。拿两个集合的元素挨个比较。

注:当collection接口的实现类对象中的元素为引用对象时,该引用对象需要重写equals方法,不然默认比较的是引用地址,而非引用的对象内容。

Collection<Object> collection = new ArrayList<>();
collection.add(123);
collection.add(456);
collection.add(new Person(3000, "Tom", 19));

Collection<Object> collection1 = new ArrayList<>();
collection1.add(123);
collection1.add(456);
collection1.add(new Person(3000, "Tom", 19));

boolean isContains = collection.contains(new Person(3000, "Tom", 19));
System.out.println("collection包含new Person对象:" + isContains);

boolean b = collection.containsAll(collection1);
System.out.println("collection包含collection1的所有元素:" + b);

boolean equals = collection.equals(collection1);
System.out.println("collection与collection1是否相等:" + equals);

//若在Person类中重写了equals方法,输出:
包含:true
包含collection1的所有元素:true
collection与collection1是否相等:true

//若Person类中未重写equals方法,输出:
collection包含new Person对象:false
collection包含collection1的所有元素:false
collection与collection1是否相等:false

6、删除

 boolean remove(Object obj) :通过元素的equals方法判断是否是要删除的那个元素。只会删除找到的第一个元素
 boolean removeAll(Collection coll):取当前集合的差集

7、取两个集合的交集

 boolean retainAll(Collection c):把交集的结果存在当前集合中,不影响c

在这里插入图片描述
8、集合是否相等:若比较ArrayList,因为是有序的集合,若元素顺序不同,也会返回false。

 boolean equals(Object obj)

如下结果输出false,由于collection与collection1的元素顺序不同:

Collection<Object> collection = new ArrayList<>();
collection.add(123);
collection.add(456);
collection.add(true);

Collection<Object> collection1 = new ArrayList<>();
collection1.add(456);
collection1.add(123);
collection1.add(true);

boolean equals = collection.equals(collection1);
System.out.println(equals);

9、转成对象数组

 Object[] toArray()


Object[] objects = collection.toArray();
for (Object object : objects) {
    System.out.println(object);
}

10、获取集合对象的哈希值

hashCode()


Collection<Object> collection = new ArrayList<>();
collection.add(123);
System.out.println(collection.hashCode());

11、遍历
iterator():返回迭代器对象,用于集合遍历

Iterator<Object> iterator = collection.iterator();

while (iterator.hasNext()) {
    System.out.println(iterator.next());
}

12、取两个集合的差集

boolean removeAll(Collection c);     求出差集,存到当前集合里。

在这里插入图片描述

4.Iterator迭代器接口

定义: 提供一种方法访问一个容器(container)对象中各个元素,而又不需暴露该对象的内部细节。 迭代器模式,就是为容器而生。

  • Iterator对象称为迭代器(设计模式的一种),主要用于遍历 Collection 集合中的元素。
  • Collection接口继承了java.lang.Iterable接口,该接口有一个iterator()方法,那么所有实现了Collection接口的集合类都有一个iterator()方法,用以返回一个实现了Iterator接口的对象。
  • Iterator 仅用于遍历集合,Iterator 本身并不提供承装对象的能力。如果需要创建Iterator 对象,则必须有一个被迭代的集合。
  • 集合对象每次调用iterator()方法都得到一个全新的迭代器对象,默认游标都在集合的第一个元素之前。

Iterator接口的方法:在这里插入图片描述
:在调用it.next()方法之前必须要调用it.hasNext()进行检测。若不调用,且下一条记录无效,直接调用it.next()会抛出NoSuchElementException异常。

Iterator接口remove()方法

  • Iterator可以删除集合的元素,但是是遍历过程中通过迭代器对象的remove方法,不是集合对象的remove方法。
    执行remove方法后,集合中相应元素会被移除。
Iterator iter = coll.iterator();//回到起点
    while(iter.hasNext()){
        Object obj = iter.next();
        if(obj.equals("Tom")){
        iter.remove();
    }
}

通过foreach循环遍历集合元素

  • Java 5.0 提供了 foreach 循环迭代访问 Collection和数组。
  • 遍历操作不需获取Collection或数组的长度,无需使用索引访问元素。
  • 遍历集合的底层调用Iterator完成操作。
  • foreach还可以用来遍历数组
for (Object obj : collection) {
    System.out.println(obj);
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值