Java 集合简介 一

什么是集合?

集合就是由若干个确定的元素所构成的整体。例如,5只小兔构成的集合:
在这里插入图片描述

在数学中,我们经常遇到集合的概念。例如:
● 有限集合
○ 一个班所有的同学构成的集合;
○ 一个网站所有的商品构成的集合;
● 无限集合
○ 整数集合
○ 有理数集合
○ 实数集合

为什么要在计算机中引入集合呢?

这是为了方便处理一组类似数据,例如:
● 计算所有同学的总成绩和平均成绩;
● 列举所有的商品名称和价格;

在 Java 中,如果一个 Java 对象可以在内部持有若干其它 Java 对象,并对外提供访问接口,我们把这种 Java 对象称为 集合。
案例:

String[] names = new String[10]; //可以持有 10 个 String 对象
names[0] = "Hello"; //放入 String 对象
names[1] = "World";
String name = names[0]; //获取 String 对象

既然 Java 提供了数组来充当集合,那么,为什么我们还需要其它集合类?
这是因为数组有如下限制:
● 数组大小固定不变
● 数组只能按索引存取
因此,我们需要各种不同类型的集合类来处理不同的数据,例如:
● 可变大小的顺序链表
● 保证无重复元素的集合

Collection

Java 标准库自带的 java.util包提供了集合类:Collection,它是除 Map外所有其它集合类的根接口。
Java 的 java.util包主要提供了以下三种类型的集合:
● List:一种有序列表的集合;
● Set:一种保证没有重复元素的集合;
● Map:一种通过键值(key-value)查找的映射表集合;

Java 集合的设计有以下几个特点:
● 实现了接口和实现类相分离。比如,有序表的接口是 List,具体的实现类有 ArrayList,LinkList 等;
● 支持泛型,我们可以限制在一个集合中只能放入同一种数据类型的元素。比如:List<String> list = new ArrayList<>();//只能放入 String 类型
Java 访问集合总是通过统一的方式——迭代器(Iterator)来实现,它最明显的好处在于无需知道集合内部元素是按什么方式存储的。

由于Java的集合设计非常久远,中间经历过大规模改进,我们要注意到有一小部分集合类是遗留类,不应该继续使用:
● Hashtable:一种线程安全的Map实现;
● Vector:一种线程安全的List实现;
● Stack:基于Vector实现的LIFO的栈。
还有一小部分接口是遗留接口,也不应该继续使用:
● Enumeration:已被Iterator取代。

参考文章

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值