Java(七)——集合框架---Collection (集合) 、Iterator接口、List接口

本文介绍了Java集合框架的起源、结构,重点讲解了Collection接口、Iterator接口以及List接口的特性与方法。集合框架解决了数组长度固定的弊端,提供了灵活的数据存储方式。在迭代器的使用中,介绍了并发修改异常的产生原因及避免方法,并探讨了List接口的实现类如ArrayList和LinkedList的数据结构及其优缺点。
摘要由CSDN通过智能技术生成

集合框架由来

Java 集合框架主要包括两种类型的容器,一种是集合(Collection),存储一个元素集合,另一种是图(Map),存储键/值对映射。Collection 接口又有 3 种子类型,List、Set 和 Queue,再下面是一些抽象类,最后是具体实现类,常用的有 ArrayListLinkedListHashSet、LinkedHashSet、HashMap、LinkedHashMap 等等。

集合框架是一个用来代表和操纵集合的统一架构。所有的集合框架都包含如下内容:

  • 接口:是代表集合的抽象数据类型。例如 Collection、List、Set、Map 等。之所以定义多个接口,是为了以不同的方式操作集合对象

  • 实现(类):是集合接口的具体实现。从本质上讲,它们是可重复使用的数据结构,例如:ArrayList、LinkedList、HashSet、HashMap。

  • 算法:是实现集合接口的对象里的方法执行的一些有用的计算,例如:搜索和排序。这些算法被称为多态,那是因为相同的方法可以在相似的接口上有着不同的实现。

除了集合,该框架也定义了几个 Map 接口和类。Map 里存储的是键/值对。尽管 Map 不是集合,但是它们完全整合在集合中。

JDK1.2版本后,出现这个集合框架,到JDK1.5后,大幅度优化.

  • 集合本质上是存储对象的容器

  • 数组也能存储对象,数组弊端就是定长

  • 解决数组的问题,开发出来集合框架,集合框架无需考虑长度

  • 集合和数组的区别与共同点

    • 集合,数组都是容器,都可以存储数据

    • 集合只存储引用数据类型,不存储基本数据类型

    • 数组可以存储基本类型,也可以存储引用类型

    • 数组定长,集合容器变长

牢记 : 数据多了存数组,对象多了存集合

  • 集合学习的关键点

    • 怎么存储数据

    • 怎么取出数据

    • 选择哪种容器

1 Collection 接口

Collection 是最基本的集合接口,一个 Collection 代表一组 Object,即 Collection 的元素, Java不提供直接继承自Collection的类,只提供继承于的子接口(如List和set)。

Collection 接口存储一组不唯一,无序的对象。

2 List 接口

List接口是一个有序的 Collection,使用此接口能够精确的控制每个元素插入的位置,能够通过索引(元素在List中位置,类似于数组的下标)来访问List中的元素,第一个元素的索引为 0,而且允许有相同的元素。

List 接口存储一组不唯一,有序(插入顺序)的对象。

3 Set

Set 具有与 Collection 完全一样的接口,只是行为上不同,Set 不保存重复的元素。

Set 接口存储一组唯一,无序的对象。

4 SortedSet
继承于Set保存有序的集合。
5 Map

Map 接口存储一组键值对象,提供key(键)到value(值)的映射。

6 Map.Entry
描述在一个Map中的一个元素(键/值对)。是一个 Map 的内部接口。
7 SortedMap
继承于 Map,使 Key 保持在升序排列。
8 Enumeration
这是一个传统的接口和定义的方法,通过它可以枚举(一次获得一个)对象集合中的元素。这个传统接口已被迭代器取代。

集合框架的继承体系

  • Collection (集合) 接口 单列集合,单身狗     一次装一个类型

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值