1
1
## 一、Java集合类简介:
2
2
Java集合大致可以分为Set、List、Queue和Map四种体系。
3
+
3
4
其中Set代表无序、不可重复的集合;List代表有序、重复的集合;而Map则代表具有映射关系的集合。Java 5 又增加了Queue体系集合,代表一种队列集合实现。
4
5
5
6
Java集合就像一种容器,可以把多个对象(实际上是对象的引用,但习惯上都称对象)“丢进”该容器中。从Java 5 增加了泛型以后,Java集合可以记住容器中对象的数据类型,使得编码更加简洁、健壮。
@@ -9,25 +10,34 @@ Java集合就像一种容器,可以把多个对象(实际上是对象的引
9
10
②.数组元素即可以是基本类型的值,也可以是对象。集合里只能保存对象(实际上只是保存对象的引用变量),基本数据类型的变量要转换成对应的包装类才能放入集合类中。
10
11
### 2.Java集合类之间的继承关系:
11
12
Java的集合类主要由两个接口派生而出:Collection和Map,Collection和Map是Java集合框架的根接口。
13
+
12
14
![ ] ( http://upload-images.jianshu.io/upload_images/3985563-e7febf364d8d8235.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240 )
15
+
13
16
图中,ArrayList,HashSet,LinkedList,TreeSet是我们经常会有用到的已实现的集合类。
14
17
15
18
Map实现类用于保存具有映射关系的数据。Map保存的每项数据都是key-value对,也就是由key和value两个值组成。Map里的key是不可重复的,key用户标识集合里的每项数据。
16
19
17
20
![ ] ( http://upload-images.jianshu.io/upload_images/3985563-06052107849a7603.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240 )
21
+
18
22
图中,HashMap,TreeMap是我们经常会用到的集合类。
23
+
19
24
## 二、Collection接口:
20
25
### 1.简介
21
26
Collection接口是Set,Queue,List的父接口。Collection接口中定义了多种方法可供其子类进行实现,以实现数据操作。由于方法比较多,就偷个懒,直接把JDK文档上的内容搬过来。
22
27
#### 1.1.接口中定义的方法
23
28
![ ] ( http://upload-images.jianshu.io/upload_images/3985563-414332ffe4733274.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240 )
29
+
24
30
可以看出Collection用法有:添加元素,删除元素,返回Collection集合的个数以及清空集合等。
25
31
其中重点介绍iterator()方法,该方法的返回值是Iterator<E >。
32
+
26
33
#### 1.2.使用Iterator遍历集合元素
27
34
Iterator接口经常被称作迭代器,它是Collection接口的父接口。但Iterator主要用于遍历集合中的元素。
28
35
Iterator接口中主要定义了2个方法:
36
+
29
37
![ ] ( http://upload-images.jianshu.io/upload_images/3985563-63737a2d81713a47.png?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240 )
38
+
30
39
下面程序简单示范了通过Iterator对象逐个获取元素的逻辑。
40
+
31
41
``` java
32
42
public class IteratorExample {
33
43
public static void main (String [] args ){
@@ -90,26 +100,40 @@ public class IteratorExample {
90
100
91
101
下面具体介绍Collection接口的三个子接口Set,List,Queue。
92
102
### 2.Set集合
93
- ####简介
103
+ #### 简介
104
+
94
105
Set集合与Collection集合基本相同,没有提供任何额外的方法。实际上Set就是Collection,只是行为略有不同(Set不允许包含重复元素)。
106
+
95
107
Set集合不允许包含相同的元素,如果试图把两个相同的元素加入同一个Set集合中,则添加操作失败,add()方法返回false,且新元素不会被加入。
108
+
96
109
### 3.List集合
97
110
#### 3.1.简介
98
111
List集合代表一个元素有序、可重复的集合,集合中每个元素都有其对应的顺序索引。List集合允许使用重复元素,可以通过索引来访问指定位置的集合元素 。List集合默认按元素的添加顺序设置元素的索引,例如第一个添加的元素索引为0,第二个添加的元素索引为1......
112
+
99
113
List作为Collection接口的子接口,可以使用Collection接口里的全部方法。而且由于List是有序集合,因此List集合里增加了一些根据索引来操作集合元素的方法。
114
+
100
115
#### 3.2.接口中定义的方法
101
116
> ** void add(int index, Object element):** 在列表的指定位置插入指定元素(可选操作)。
117
+ >
102
118
> ** boolean addAll(int index, Collection<? extends E> c) : ** 将集合c 中的所有元素都插入到列表中的指定位置index处。
119
+ >
103
120
> ** Object get(index):** 返回列表中指定位置的元素。
121
+ >
104
122
> ** int indexOf(Object o):** 返回此列表中第一次出现的指定元素的索引;如果此列表不包含该元素,则返回 -1。
123
+ >
105
124
> ** int lastIndexOf(Object o):** 返回此列表中最后出现的指定元素的索引;如果列表不包含此元素,则返回 -1。
125
+ >
106
126
> ** Object remove(int index): ** 移除列表中指定位置的元素。
127
+ >
107
128
> ** Object set(int index, Object element):** 用指定元素替换列表中指定位置的元素。
129
+ >
108
130
> ** List subList(int fromIndex, int toIndex): ** 返回列表中指定的 fromIndex(包括 )和 toIndex(不包括)之间的所有集合元素组成的子集。
131
+ >
109
132
> ** Object[ ] toArray():** 返回按适当顺序包含列表中的所有元素的数组(从第一个元素到最后一个元素)。
110
133
111
134
除此之外,Java 8还为List接口添加了如下两个默认方法。
112
135
> ** void replaceAll(UnaryOperator operator):** 根据operator指定的计算规则重新设置List集合的所有元素。
136
+ >
113
137
> ** void sort(Comparator c):** 根据Comparator参数对List集合的元素排序。
114
138
115
139
### 4.Queue集合
@@ -121,13 +145,18 @@ Queue用户模拟队列这种数据结构,队列通常是指“先进先出”
121
145
## 三、Map集合
122
146
### 1.简介
123
147
Map用户保存具有映射关系的数据,因此Map集合里保存着两组数,一组值用户保存Map里的key,另一组值用户保存Map里的value,key和value都可以是任何引用类型的数据。Map的key不允许重复,即同一个Map对象的任何两个key通过equals方法比较总是返回false。
148
+
124
149
如下图所描述,key和value之间存在单向一对一关系,即通过指定的key,总能找到唯一的、确定的value。从Map中取出数据时,只要给出指定的key,就可以取出对应的value。
150
+
125
151
![ ] ( http://upload-images.jianshu.io/upload_images/3985563-51f6c5278df941fe.jpg?imageMogr2/auto-orient/strip%7CimageView2/2/w/1240 )
152
+
126
153
### 2.Map集合与Set集合、List集合的关系
127
154
** ①.与Set集合的关系**
155
+
128
156
如果 把Map里的所有key放在一起看,它们就组成了一个Set集合(所有的key没有顺序,key与key之间不能重复),实际上Map确实包含了一个keySet()方法,用户返回Map里所有key组成的Set集合。
129
157
130
158
** ②.与List集合的关系**
159
+
131
160
如果把Map里的所有value放在一起来看,它们又非常类似于一个List:元素与元素之间可以重复,每个元素可以根据索引来查找,只是Map中索引不再使用整数值,而是以另外一个对象作为索引。
132
161
133
162
### 3.接口中定义的方法
@@ -169,7 +198,11 @@ public class MapTest {
169
198
```
170
199
输出结果:
171
200
> true
201
+ >
172
202
> true
203
+ >
173
204
> Day [ hour=2, minute=3, second=4]
205
+ >
174
206
> Day [ hour=1, minute=2, second=3]
207
+ >
175
208
> {第二个=Day [ hour=2, minute=3, second=4] }
0 commit comments