集合
1.集合的概念:集合是Java中提供的一种容器,用来储存多个数据;
2.集合和数组的区别:
- 数组:数组的长度是固定的,存储的数据类型要相同,可以存储基本数据类型和引用数据类型;
- 集合:集合的长度不是固定的,存储的数据类型可以不同,只能存储引用数据类型;
注意,用集合来存储数据的时候 存储不同类型的数据很不安全,于是我们可以使用泛型来实现集合中只能存储相同类型的数据;
集合基本分为两类:
1.Collection:单列集合,添加数据时,每次只能添加一个元素;
2.Map:双列集合,添加数据时,每次添加一对元素;
Collection
Collextion是单列集合的祖宗接口,它的功能是全部单列集合都可以继承使用的;
这是Collection中的一些方法;
小细节:contains方法的底层是通过equals方法来判断是否存在的;
所以如果集合中存储的是自定义对象,也想通过contains方法来判断是否包含,那么在Javabean类中,一定要重写equals方法;
Collection集合通用遍历方式
因为Collection集合有set儿子,而set系类集合是没有索引的,所以普通的for循环遍历实现不了;
Collection通用的遍历方式有:
迭代器遍历:
迭代器遍历最大的特点是不依赖索引;
细节注意点:
1,当你遍历完后再次使用next方法,系统会报错NoSuchElementException;
2,迭代器遍历完毕,指针并不会归位,如果还想要遍历,就要重新构造新的迭代器;
3,循环中只能使用一次next方法;
4,迭代器遍历时,不能用集合的方法进行增加或者删除,但是当你想要删除元素的时候,可以通过迭代器的删除方法删除;
增强for遍历;
增强for的底层就是迭代器Iterator,为了简化iterator的代码书写的;
使用对象:所有的单列集合和数组都能使用;
小细节:修改第三方变量的值不会影响集合中的元素;
Lambda表达式遍历;
当你遍历的时候想要删除元素的时候就选择迭代器遍历,啥也不干就选择增强for循环或Lambda表达式;
List系列集合:添加的元素是有序的,可重复,有索引;
List实现子类的特点:
- List集合类中元素有序(即添加顺序和取出顺序一致)、 且可重复
- List集合中的每个元素都有相对应的顺序索引,支持索引
- List中的元素都对应一个整数型的序号记载其在容器中的位置,可以根据其序号存取容器中对应的元素。
List集合在继承Collection集合的基础上可以通过索引来进行元素的增删查改;
小细节:根据remove来删除元素时,会优先选择根据索引来进行删除;
List集合遍历元素特有方法:ListIterator
该方法是Iterator的子接口;
改迭代器实现了在遍历的时候添加元素;
ArrayList
LinkedList
底层数据结构是链表,查询慢,增删快,但是如果操作的是首尾元素,速度也是极快的;
LinkedList本身多了很多直接操作首尾元素的特有API(接口);
Map
Map常见API:
map集合常用API示例:
package Map;
import java.util.HashMap;
import java.util.Map;
public class A01 {
public static void main(String[] args) {
//1.创建集合:
Map<String,String> m=new HashMap<>();
//2.添加元素;
m.put("宁舒意","李思敏");
m.put("刘洋","迪丽热巴");
m.put("李心力","彭航博");
//put方法的细节:
// 添加和覆盖;
//在添加数据的时候,如果键不存在,那么直接把键值对对象添加到map集合当中,方法返回null;
//在添加数据的时候,如果键是存在的,那么会把原有的键值对覆盖,会把覆盖的值进行返回;
// String s=m.put("刘洋","江疏影");
// System.out.println(s);
//删除;
//String result = m.remove("李心力");
//System.out.println(result);
//清空;
//m.clear();
//判断是否包含;
// boolean KeyResult=m.containsKey("宁舒意");
// System.out.println(KeyResult);
// boolean ValueResult = m.containsValue("李思敏");
// System.out.println(ValueResult);
//判段集合是否为空;
// boolean result =m.isEmpty();
// System.out.println(result);
int size =m.size();
System.out.println(size);
//3.打印集合
System.out.println(m);
}
}
Set系列集合:添加的元素是无序,不重复,无索引;
泛型
泛型的好处:
- 统一数据类型;
- 把运行时期的问题提前到了编译时期,避免了强制类型转换可能出现的异常,因为在编译阶段类型就能确定下来;
![]()
应用场景:
1.如果我们在定义类,方法,接口的时候,如果类型不确定,就可以定义泛型类,泛型方法,泛型接口;
2.如果类型不确定,但是能知道以后只能传递继承某个体系中的,就可以使用泛型的通 配符;
泛型的通配符:
关键点:可以限制类型的范围;