J a v a C o l l e c t i o n 集合 \huge{Java \ Collection集合} Java Collection集合
背景
数组定义的时候就必须确定数组的大小,也就是数组的长度一定是固定的。并且对于数组中元素的增删非常麻烦。但是集合类型完全相反,它的长度不确定,随用随加,并且对于集合中元素的增删也非常方便。
概述
集合:一种存储对象数据的容器。
特点
- 集合的大小不固定,使用后可以动态变化,加入对象类型也不固定,什么类型的都可以加入进去(
乱炖)。 - 集合非常适合做元素的增删操作,只需调用相关的API就可以了,非常的快捷。
- 不同于数组可以存储基本类型和引用类型,集合只能存储引用类型。如果要让集合存储基本类型,则要对于集合加上对应类型的包装类(后续集合泛型中提到)。
集合类体系结构
集合这个大概念下分为两个子概念:
Collection单列
:所谓单列就是每个元素只包含一个值(单体现)。Map双列
:每个元素包含两个值(键值对)
C o l l e c t i o n Collection Collection
上图中
蓝色
\color{blue}蓝色
蓝色都是接口,
红色
\color{red}红色
红色都是实现类。
C o l l e c t i o n Collection Collection集合特点
- List系列集合:添加元素有序、可重复、有索引。
ArrayList
、LinkedList
:有序、可重复、有索引。 - Set系列集合:添加元素无序、不重复、无索引。
HashSet
:无序、不重复、无索引。
LinkedHashSet
:有序、不重复、无索引。
TreeSet
: 按照大小默认升序排序 \color{red}按照大小默认升序排序 按照大小默认升序排序,不重复、无索引
代码实例
①. Collection
的特点:有序、可重复、有索引
例:
Collection list = new ArrayList();
//add():向集合中添加元素,各种类型都可以
list.add("Java");
list.add("Java");
list.add("Mybatis");
//可重复
list.add(23);
list.add(23);
list.add(false);
list.add(false);
System.out.println(list);
运行结果:
添加的元素都是按照代码中添加的顺序加入的(有序)。
②. HashSet
的特点:无序、不重复、无索引
例:
Collection list1 = new HashSet();
list1.add("Java");
list1.add("Java");
list1.add("Mybatis");
list1.add(23);
list1.add(23);
list1.add(false);
list1.add(false);
System.out.println(list1);
运行结果:
元素不重复,并且打印出来的顺序与代码中的顺序不一致(无序)。
③. 集合中的泛型
本来集合中的元素是可以添加入任意类型的,但是加入泛型的限定之后,就只能添加泛型类型了。
❗:如果要在集合中加入基本元素就必须集合的泛型设定为相应的包装类。因为Java中默认集合类型中存储的都是对象,所以将基本类型的数据加入到集合中的时候会完成基本类型到包装类型的自动装箱。
例:
Collection<String> list2 = new ArrayList<>(); // JDK 7开始之后后面类型申明可以不写
//限定只能集合中只能加入String类型的对象了
list2.add("Java");
// list2.add(23); 加入失败不符合泛型规定
list2.add("黑马");
// ❗集合和泛型不支持基本数据类型,只能支持引用数据类型
// Collection<int> list3 = new ArrayList<>();
Collection<Integer> list3 = new ArrayList<>();
//❗基本类型向包装类型自动装箱
//自动装箱 int -> Integer
list3.add(23);
list3.add(233);
list3.add(2333);
Collection<Double> list4 = new ArrayList<>();
//自动装箱 double -> Double
list4.add(23.4);
list4.add(233.0);
list4.add(233.3);