✅作者简介:C/C++领域新星创作者,热爱编程
✨个人主页:叶落秋白的主页
🔥系列专栏:JavaSE精品总结
📃推荐一款模拟面试、刷题神器👉注册免费刷题
🔥前言
别看我是个
C/C++
领域的活跃博主,其实放假以来都在卷java
,就在昨天学习了java的反射和设计模式,正式结束了第一阶段。因此需要对重点部分做分析和总结来巩固这些基础知识,那么今天的主题就是List、Set
集合的概念和使用了,接下来就请大家开始享用干货吧!
是一个工具类,作用为存储多个数据,通常用于替代数组
集合的特点
Object
对象
java.util
包ArrayList
最常用
创建
通常使用多态
List 集合名=new 实现类名();
常用方法
boolean add(元素)
:将元素添加至集合末尾void add(下标,元素)
:将元素添加至指定下标位置boolean addAll(集合名)
:将指定集合所有元素添加至当前集合末尾boolean addAll(下标,集合名)
:将指定集合所有元素添加至当前集合指定下标位置void clear()
:清空集合元素int size()
:获取集合长度boolean contains(元素)
:判断集合中是否包含指定元素boolean containsAll(集合名)
:判断集合中是否包含指定集合的所有元素元素 get(下标)
:获取指定下标位置上的元素int indexOf(元素)
:获取指定元素第一次出现的下标,不存在返回-1int lastIndexOf(元素)
:获取指定元素最后一次出现的下标,不存在返回-1boolean isEmpty()
:判断集合元素是否为空,不能判比null值元素 remove(下标)
:移除指定下标的元素,返回该元素元素 set(下标,新值)
:将指定下标位置的值替换为新值,返回旧值void sort(比较器实现类对象)
:对集合元素按照指定规则排序Object[] toArray()
:将集合转换为数组代码示例
public class Test {
public static void main(String[] args) {
List list = new ArrayList();
list.add(66);
list.add(5);
list.add(77);//66 5 77
list.add(2,44);//66 5 44 77
List list2 = new ArrayList();
list2.add(2);
list2.add(1);
list.addAll(list2);//66 5 44 77 2 1
list.addAll(1, list2);//66 2 1 5 44 77 2 1
System.out.println("清空之前:"+list.size());
// list.clear();
// System.out.println("清空之后:"+list.size());
System.out.println(list.contains(5));//t
System.out.println(list.containsAll(list2));//t
List list3 = new ArrayList();
list3.add(66);
list3.add(77);
list3.add(88);
System.out.println(list.containsAll(list3));//f
System.out.println(list.get(3));//5
System.out.println(list.indexOf(88));//-1
System.out.println(list.lastIndexOf(2));//6
//list.clear();
System.out.println(list.isEmpty());
List list4=null;
//System.out.println(list4.isEmpty()); 空指针异常
System.out.println(list.remove(3));//66 2 1 44 77 2 1
// System.out.println(list.remove(2));
list.set(1, 88);//66 88 1 44 77 2 1
Object[] os=list.toArray();
for(int i=0;i<os.length;i++){
System.out.print(os[i]+" ");
}
System.out.println();
}
}
for (int i = 0; i < 集合名.size(); i++) {
//i代表当前下标
//通过集合名.get(i)的方式获取当前元素
}
如:
for (int i = 0; i < list.size(); i++) {
System.out.print(list.get(i)+" ");
}
System.out.println();
hasNext()
:判断是否存在下一元素next()
:指针后移,获取下一元素tips:迭代过程中不允许对集合进行增删操作
外遍历forEach
for(数据类型 元素名(随便起) : 集合名){
//元素名就代表当前元素
}
如:
for (Object o: list) {
System.out.print(o+" ");
}
System.out.println();
自遍历forEach
//匿名内部类
集合名.forEach(new Consumer() {
@Override
public void accept(Object o) {
//o就代表当前元素
}
});
//lambda简化
集合名.forEach(o-> {o就代表当前元素});
如:
list.forEach(new Consumer() {
@Override
public void accept(Object o) {
System.out.print(o + " ");
}
});
System.out.println();
// lambda
list.forEach(o-> System.out.print(o+" "));
作用
用于集合中,可以约束集合存储的数据类型
语法
List<数据类型> 集合名=new 实现类名<数据类型>();
使用
1. 如果集合中存放基本类型,则泛型必须声明为其包装类型
2. 声明泛型之后,集合中不允许存放其他类型的数据
3. 前后类型声明必须一致
4. 等号后边的泛型不声明,语法不规范
5. 等号前边的泛型不声明,泛型无意义
List list = new ArrayList();
list.add(66);
list.add(88);
/* list.add("abc");
list.add(5.5);*/
list.forEach(new Consumer() {
@Override
public void accept(Integer i) {
System.out.println(i);
}
});
Collection
List
和Set
的父接口Collection
或Map
派生特点
HashSet
LinkedHashSet
TreeSet
创建
利用多态
Set<泛型类型> 集合名 = new 实现类名<泛型类型>();
常用方法
Collection
哈希表的去重过程
先通过调用元素的
hashCode()
方法得到哈希码值
然后通过哈希码值%
数组长度得到存放下标
若该下标位置未存放元素,则直接存放
若已存有元素,则调用当前元素的equals()方法与其位置的所有元素进行值的比较
都不相同,则链表存放
若有相同,舍弃当前元素
hashCode
和equals
才能保证去重LinkedHashSet
能够保证元素存入和取出顺序一致TreeSet
可以实现对元素进行默认的升序排序
public class Test2 {
public static void main(String[] args) {
Set<Student> set = new TreeSet<Student>(new Comparator<Student>() {
@Override
public int compare(Student o1, Student o2) {
//根据学生年龄从大到小排序
return o2.getAge()-o1.getAge();
}
});
set.add(new Student("张三", 20));
set.add(new Student("lisi", 21));
set.add(new Student("lisi", 21));
set.add(new Student("wangwu", 22));
set.add(new Student("maliu", 19));
set.forEach(s-> System.out.println(s));
}
}
List
接口是一个有序的Collection
,使用此接口能够精确的控制每个元素插入的位置,能够通过索引(元素在List中位置,类似于数组的下标)来访问List中的元素,第一个元素的索引为 0,而且允许有相同的元素。List 接口存储一组不唯一,有序的对象。
Set
具有与Collection
完全一样的接口,只是行为上不同,Set 不保存重复的元素。Set 接口存储一组唯一,无序的对象。
List
ArrayList
、LinkedList
和 Vector
。ArrayList 最为流行,它提供了使用索引的随意访问,而 LinkedList 则对于经常需要从 List 中添加或删除元素的场合更为合适。set
HashSet
、LinkedHashSet
以及 TreeSet
。最流行的是基于 HashMap
实现的 HashSet;TreeSet 还实现了 SortedSet
接口,因此 TreeSet 是一个根据其 compare()
和 compareTo()
的定义进行排序的有序容器。这篇博客就分析三个集合中的两个,下一篇博客总结Map接口的基本使用并附带一些面试的老生常谈问题。码文不易,觉得帮助到你了就给个三连呗~