前言
“衣带渐宽终不悔,为伊消得人憔悴” —柳永《蝶恋花·伫倚危楼风细细》
1 Collection集合
1.1 数组和集合的区别
1. 相同点
都是容器,可以存储多个数据
2. 不同点
-
数组的长度是不可变的,集合的长度是可变的
-
数组可以存基本数据类型和引用数据类型
-
集合只能存引用数据类型,如果要存基本数据类型,需要存对应的包装类
1.2 集合类体系结构
1.3 泛型
泛型的定义格式
<类型>: 指定一种类型的格式.尖括号里面可以任意书写,例如: <T> <T,V>
1.4 Collection 集合概述和使用
1. 创建Collection集合的对象
// 1.多态的方式
Collection<String> collection = new ArrayList();
// 2.具体的实现类
ArrayList<String> list = new ArrayList<>();
2. Collection集合常用方法
方法名 | 说明 |
---|---|
boolean add(E e) | 添加元素 |
boolean remove(Object o) | 从集合中移除指定的元素 |
void clear() | 清空集合中的元素 |
boolean contains(Object o) | 判断集合中是否存在指定的元素 |
boolean isEmpty() | 判断集合是否为空 |
int size() | 集合的长度,也就是集合中元素的个数 |
1.5 Collection集合的遍历
1.5.1 迭代器遍历
1.迭代器介绍
- 迭代器,集合的专用遍历方式
- Iterator iterator(): 返回此集合中元素的迭代器,通过集合对象的iterator()方法得到
2.Iterator中的常用方法
- boolean hasNext(): 判断当前位置是否有元素可以被取出
- E next(): 获取当前位置的元素,将迭代器对象移向下一个索引位置
3.Collection集合的遍历
package com.syh;
import java.util.ArrayList;
import java.util.Collection;
import java.util.Iterator;
public class Esther {
public static void main(String[] args) {
// 1.创建集合对象
Collection<String> c = new ArrayList<>();
// 2.添加元素
c.add("a");
c.add("b");
c.add("c");
// 3.得到集合的iterator()方法
Iterator<String> it = c.iterator();
// 4.遍历集合
while (it.hasNext()) {
String s = it.next();
System.out.println(s);
}
}
}
1.5.2 增强for
1. 增强for格式
for(集合/数组中元素的数据类型 变量名 : 集合/数组名) {
}
2. 代码示例
package com.syh;
import java.util.ArrayList;
public class Esther {
public static void main(String[] args) {
// 1.创建集合对象
ArrayList<String> list = new ArrayList<>();
// 2.往集合中添加元素
list.add("a");
list.add("b");
list.add("c");
list.add("d");
// 3.遍历集合
for (String str : list) {
System.out.println(str);
}
}
}
1.5.3 lambda表达式
利用forEach方法,再结合lambda表达式的方式进行遍历
package com.syh;
import java.util.ArrayList;
import java.util.Collection;
public class Esther {
public static void main(String[] args) {
// 1.创建集合对象并添加元素
Collection<String> coll = new ArrayList<>();
// 2.往集合中添加元素
coll.add("zhangsan");
coll.add("lisi");
coll.add("wangwu");
// 3.lambda表达式
coll.forEach(s -> System.out.println(s));
}
}
2 List集合
2.1 List集合的特点
- 存取有序
- 可以重复
- 有索引
2.2 ArrayList集合的方法
方法名 | 描述 |
---|---|
void add(E element) | 插入元素到尾部 |
E remove(int index) | 删除指定索引处的元素 |
E set(int index,E element) | 修改指定索引处的元素 |
E get(int index) | 返回指定索引处的元素 |
示例代码
package com.syh;
import java.util.ArrayList;
import java.util.List;
public class Esther {
public static void main(String[] args) {
List<String> list = new ArrayList<>();
list.add("aaa");
list.add("bbb");
list.add("ccc");
add(list);
remove(list);
set(list);
get(list);
}
private static void add(List<String> list) {
// 1.在指定索引处添加元素
list.add("ddd");
System.out.println(list);
}
private static void remove(List<String> list) {
// 2.删除指定索引处的元素
String s = list.remove(3);
System.out.println(list);
}
private static void set(List<String> list) {
// 3.修改指定索引处的元素
String result = list.set(2, "qqq");
System.out.println(list);
}
private static void get(List<String> list) {
// 4.获取指定索引处的元素
String s = list.get(0);
System.out.println(s);
}
}
2.3 LinkedList集合的功能
方法名 | 说明 |
---|---|
public void addFirst(E e) | 在该列表开头插入指定的元素 |
public void addLast(E e) | 将指定的元素追加到此列表的末尾 |
public E getFirst() | 返回此列表中的第一个元素 |
public E getLast() | 返回此列表中的最后一个元素 |
public E removeFirst() | 从此列表中删除并返回第一个元素 |
public E removeLast() | 从此列表中删除并返回最后一个元素 |
示例代码
package com.syh;
import java.util.LinkedList;
public class Esther {
public static void main(String[] args) {
LinkedList<String> list = new LinkedList<>();
list.add("aaa");
list.add("bbb");
list.add("ccc");
addFirst(list);
addList(list);
getFirst(list);
getLast(list);
removeFirst(list);
removeLast(list);
}
private static void addFirst(LinkedList<String> list) {
// 1.在列表开头添加元素
list.addFirst("111");
System.out.println(list);
}
private static void addList(LinkedList<String> list) {
// 2.在列表结尾添加元素
list.addLast("222");
System.out.println(list);
}
private static void getFirst(LinkedList<String> list) {
// 3.获取列表开头的元素
String first = list.getFirst();
System.out.println(first);
}
private static void getLast(LinkedList<String> list) {
// 4.获取列表结尾的元素
String last = list.getLast();
System.out.println(last);
}
private static void removeFirst(LinkedList<String> list) {
// 5.删除列表开头的元素
String first = list.removeFirst();
System.out.println(list);
}
private static void removeLast(LinkedList<String> list) {
// 6.删除列表结尾的元素
String last = list.removeLast();
System.out.println(list);
}
}
3 Set集合
3.1 Set集合的特点
- 不可以存储重复元素
- 没有索引,不能使用普通for循环遍历
3.2 HashSet集合
1. HashSet集合概述
- 底层数据结构是哈希表
- 存取无序
- 不可以存储重复元素
- 没有索引,不能使用普通for循环遍历
2. 代码示例
package com.syh;
import java.util.HashSet;
public class Esther {
public static void main(String[] args) {
// 1.创建集合对象
HashSet<String> set = new HashSet<String>();
// 2.添加元素
set.add("hello");
set.add("world");
set.add("java");
set.add("world");
// 3.遍历
for (String s : set) {
System.out.println(s);
}
}
}
3.3 TreeSet集合
1. TreeSet集合概述
- 不可以存储重复元素
- 没有索引
- 根据其元素的自然排序进行排序
2. 代码示例
package com.syh;
import java.util.TreeSet;
public class Esther {
public static void main(String[] args) {
// 1.创建集合对象
TreeSet<Integer> ts = new TreeSet<Integer>();
// 2.添加元素
ts.add(10);
ts.add(40);
ts.add(30);
ts.add(50);
ts.add(20);
ts.add(30);
// 3.遍历集合
for(Integer i : ts) {
System.out.println(i);
}
}
}
4 Map集合
4.1 Map集合概述
Map集合是双列集合,包括键和值,例如:Map<K,V>
1. Map集合的特点
- 双列集合,一个键对应一个值
- 键不可以重复,值可以重复
2. 代码示例
package com.syh;
import java.util.HashMap;
import java.util.Map;
public class Esther {
public static void main(String[] args) {
// 1.创建集合对象
Map<String,String> map = new HashMap<String,String>();
// 2.添加元素
map.put("001","李默然");
map.put("002","徐则言");
map.put("003","辰子希");
map.put("003","云其墨");
// 3输出集合对象
System.out.println(map);
}
}
4.2 HashMap集合的方法
方法名 | 说明 |
---|---|
V put(K key,V value) | 添加元素 |
V remove(Object key) | 根据键删除键值对元素 |
void clear() | 移除所有的键值对元素 |
boolean containsKey(Object key) | 判断集合是否包含指定的键 |
boolean containsValue(Object value) | 判断集合是否包含指定的值 |
boolean isEmpty() | 判断集合是否为空 |
int size() | 集合的长度,也就是集合中键值对的个数 |
示例代码
package com.syh;
import java.util.HashMap;
import java.util.Map;
public class Esther {
public static void main(String[] args) {
// 1.创建集合对象
Map<String, String> map = new HashMap<String, String>();
// 2.添加元素
map.put("001","云其墨");
map.put("002","徐则言");
map.put("003","辰子希");
map.put("004","李默然");
// 3.根据键删除键值对元素
System.out.println(map.remove("004"));
// 4.清空键值对元素
map.clear();
// 5.判断集合是否包含指定的键
System.out.println(map.containsKey("001"));
// 6.判断集合是否包含指定的值
System.out.println(map.containsValue("李默然"));
// 7.判断集合是否为空
System.out.println(map.isEmpty());
// 8.集合的长度,也就是集合中键值对的个数
System.out.println(map.size());
//输出集合对象
System.out.println(map);
}
}
4.3 HashMap集合的获取方法
方法名 | 说明 |
---|---|
V get(Object key) | 根据键获取值 |
Set keySet() | 获取所有键的集合 |
Collection values() | 获取所有值的集合 |
Set<Map.Entry<K,V>> entrySet() | 获取所有键值对对象的集合 |
示例代码
package com.syh;
import java.util.Collection;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
public class Esther {
public static void main(String[] args) {
// 1.创建集合对象
Map<String, String> map = new HashMap<String, String>();
// 2.添加元素
map.put("001", "云其墨");
map.put("002", "徐则言");
map.put("003", "辰子希");
// 3.根据键获取值
String value = map.get("001");
System.out.println(value);
// 4.获取所有键的集合
Set<String> keySet = map.keySet();
for (String key : keySet) {
System.out.println(key);
}
// 5.获取所有值的集合
Collection<String> values = map.values();
for (String value1 : values) {
System.out.println(value1);
}
// 6.获取所有键值对的集合
System.out.println(map.entrySet());
}
}
4.4 HashMap集合的遍历
- 第一种根据键获取值
- 第二种直接获取Map集合对象
代码实现
package com.syh;
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
public class Esther {
public static void main(String[] args) {
// 1.创建集合对象
Map<String, String> map = new HashMap<String, String>();
// 2.添加元素
map.put("001", "云其墨");
map.put("002", "徐则言");
map.put("003", "辰子希");
map.put("004", "李默然");
// 3.根据键获取值遍历
Set<String> keySet = map.keySet();
for (String key : keySet) {
String value = map.get(key);
System.out.println(key + "," + value);
}
// 4.获取所有键值对对象的集合遍历
Set<Map.Entry<String, String>> entrySet = map.entrySet();
for (Map.Entry<String, String> me : entrySet) {
String key = me.getKey();
String value = me.getValue();
System.out.println(key + "," + value);
}
}
}
4.5 TreeMap集合
1. TreeMap集合概述
- TreeMap底层是红黑树结构
- 依赖自然排序或者比较器排序,对键进行排序
- 如果键存储的是自定义对象,需要实现Comparable接口或者在创建TreeMap对象时候给出比较器排序规则
2. 代码示例
package com.syh;
import java.util.TreeMap;
public class Esther {
public static void main(String[] args) {
// 1.创建TreeMap集合对象
TreeMap<String, String> tm = new TreeMap<>();
// 2.添加元素
tm.put("江苏省", "南京市");
tm.put("广东省", "广州市");
tm.put("浙江省", "杭州市");
// 3.遍历集合
tm.forEach((String key, String value) -> System.out.println(key + "---" + value));
}
}