集合(Collection)
前几天做数据结构题碰到了集合,当时并没有学,只是通过做题对此稍微有了了解。今天正好学到了,来做一下学习记录。
一.集合总体框架

由上图可知,集合的实现方式有两大类:
(1)线性接口:该集合的顶层接口是java.util.Collection,所有集合中的数据都是将自身存储到集合中。
该接口下有两个子接口:
java.util.List 有序,可重复
java.util.Set 无序,不可重复
(2)键值映射:该集合的顶层接口是java.util.Map,所有集合中的数据都是以键值映射的方式存储到集合中,即都必须创建一个关键字key,对应一个值value,其中key是唯一的。
我们常用的三个接口是List,Set,Map。

二.集合的功能
集合和数组一样,都是用来存储相同类型数据的容器。
现在我们使用集合时都会和泛型一起使用,使用泛型来约束集合中可以保存的数据类型。
三.常用实现类

我们常用的实现类有:
ArrayList——有序可重复,线性集合中使用最多的一个类,就是一个可变长度的数组。查找易,增删难
LinkedList——有序可重复,链表方式实现的线性集合,增删改易,查找难;
HashSet——散列集合,无序不重复。Set接口中的常用类;
HashMap——Hash算法的键值映射集合,按键找值;
TreeSet——有序不重复,是个有序的Set接口的实现类,经过了排序;
TreeMap——有序的Map接口的实现类。
四.集合的排序
集合的排序指的是List集合的排序,因为Set是无序的,不需要排序。
4.1String类型的集合排序
针对List集合进行排序的方法是Collections.sort()。

是Collections类里的一个静态方法。
我们看String类可见,它实现了Comparable接口,所以具有比较的能力。

案例:
package com.xja.test3; import java.io.InputStream;
import java.util.ArrayList;
import java.util.Collections; /**
* @描述:
* @author:
* @date:2023/2/2119:13
* @version:
**/
public class T1 {
public static void main(String[] args) {
ArrayList<String> list = new ArrayList<>();
list.add("hij");
list.add("abc");
list.add("def");
//未排序前,默认添加顺序排序
System.out.println(list);
//排序
Collections.sort(list);
//排序后
System.out.println(list);
}
}
输出结果:

4.2比较器接口
比较器接口,代表一种可以进行比较的能力,任何类实现了比较器接口,并重写相应的方法,就表示这个类具备了比较大小的能力。
Java中提供了两个比较器接口:
(1)Comparable接口(内置比较器接口) 自然排序
一般写在实体类里,使得该类的某个属性可以进行比较。从而对该实体类的对象进行排序。如:学生在学校默认都是按学号进行排序。
(2)Comparator接口(外置比较器接口) 扩展排序
当我们使用别人编写好的一个类,该类中的比较器不符合我们的要求 ,就可以使用外置比较器。实现Comparator接口,重写comparaTo()方法即可。
如:学校运动会,按跑步成绩进行排序;一次摸底考试,按考试成绩排序,那么之前的按学号排序就不符合我们的需求,这时候就用到了外置比较器。
4.2.1内置比较器接口使用案例
package com.xja.test3; /**
* @描述:学生类(实体类)
* @author:
* @date:2023/2/2121:06
* @version:
**/
public class Stu implements Comparable<Stu>{
private Integer sid;
private String sname;
private Double sscore; @Override
public int compareTo(Stu o) {
return this.sname.length()-o.sname.length();
} public Stu() {
} public Stu(Integer sid, String sname, Double sscore) {
this.sid = sid;
this.sname = sname;
this.sscore = sscore;
} public Integer getSid() {
return sid;
} public void setSid(Integer sid) {
this.sid = sid;
} public String getSname() {
return sname;
} public void setSname(String sname) {
this.sname = sname;
} public Double getSscore() {
return sscore;
} public void setSscore(Double sscore) {
this.sscore = sscore;
} @Override
public String toString() {
return "Stu{" +
"sid=" + sid +
", sname='" + sname + '\'' +
", sscore=" + sscore +
'}';
}
}
package com.xja.test3; import java.util.ArrayList;
import java.util.Collections; /**
* @描述:内置比较器测试类
* @author:
* @date:2023/2/2121:13
* @version:
**/
public class StuTest1 {
public static void main(String[] args) {
ArrayList<Stu> list = new ArrayList<>();
list.add(new Stu(2,"aa",90D));
list.add(new Stu(1,"cccc",89D));
list.add(new Stu(4,"b",78D));
list.add(new Stu(3,"eee",99D));
//排序前
System.out.println(list);
//排序后
Collections.sort(list);
System.out.println(list);
}
}
输出结果:
[Stu{sid=2, sname='aa', sscore=90.0}, Stu{sid=1, sname='cccc', sscore=89.0}, Stu{sid=4, sname='b', sscore=78.0}, Stu{sid=3, sname='eee', sscore=99.0}]
[Stu{sid=4, sname='b', sscore=78.0}, Stu{sid=2, sname='aa', sscore=90.0}, Stu{sid=3, sname='eee', sscore=99.0}, Stu{sid=1, sname='cccc', sscore=89.0}]
4.2.2外置比较器接口使用案例
package com.xja.test3; import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator; /**
* @描述:内置比较器测试类
* @author:
* @date:2023/2/2121:13
* @version:
**/
public class StuTest1{
public static void main(String[] args) {
ArrayList<Stu> list = new ArrayList<>();
list.add(new Stu(2,"aa",90D));
list.add(new Stu(1,"cccc",89D));
list.add(new Stu(4,"b",78D));
list.add(new Stu(3,"eee",99D));
//排序前
System.out.println(list);
//内置比较器排序后
Collections.sort(list);
System.out.println(list); //外置比较器使得按成绩排序
Collections.sort(list, new Comparator<Stu>() {
@Override
public int compare(Stu o1, Stu o2) {
if (o1.getSscore()>o2.getSscore()){
return 1;
}else {
return -1;
}
}
});
System.out.println(list);
}
}
输出结果:
[Stu{sid=2, sname='aa', sscore=90.0}, Stu{sid=1, sname='cccc', sscore=89.0}, Stu{sid=4, sname='b', sscore=78.0}, Stu{sid=3, sname='eee', sscore=99.0}]
[Stu{sid=4, sname='b', sscore=78.0}, Stu{sid=2, sname='aa', sscore=90.0}, Stu{sid=3, sname='eee', sscore=99.0}, Stu{sid=1, sname='cccc', sscore=89.0}]
[Stu{sid=4, sname='b', sscore=78.0}, Stu{sid=1, sname='cccc', sscore=89.0}, Stu{sid=2, sname='aa', sscore=90.0}, Stu{sid=3, sname='eee', sscore=99.0}]
集合(Collection)的更多相关文章
- Guava库介绍之集合(Collection)相关的API
作者:Jack47 转载请保留作者和原文出处 欢迎关注我的微信公众账号程序员杰克,两边的文章会同步,也可以添加我的RSS订阅源. 本文是我写的Google开源的Java编程库Guava系列之一,主要介 ...
- 【再探backbone 02】集合-Collection
前言 昨天我们一起学习了backbone的model,我个人对backbone的熟悉程度提高了,但是也发现一个严重的问题!!! 我平时压根没有用到model这块的东西,事实上我只用到了view,所以昨 ...
- 5、数组和集合--Collection、Map
一.数组:同一个类型数据的集合,其实他也是一个容器 1.数组的好处:可以自动给数组中的元素从0开始编号,方便操作这些数据 2.数组的定义: 在Java中常见: 格式1: 类型 [] 数组名 = ne ...
- WCF分布式开发步步为赢(8):使用数据集(DataSet)、数据表(DataTable)、集合(Collection)传递数据
数据集(DataSet).数据表(DataTable).集合(Collection)概念是.NET FrameWork里提供数据类型,在应用程序编程过程中会经常使用其来作为数据的载体,属于ADO.NE ...
- 在含有null值的复杂类的集合(Collection)中取最大值
在日常编程中,经常遇到要在一组复杂类的集合(Collection)中做比较.取最大值或最小值. 举个最简单的例子,我们要在一个如下结构的集合中选取包含最大值的元素: public class Clas ...
- 集合Collection总览
前言 声明,本文使用的是JDK1.8 从今天开始正式去学习Java基础中最重要的东西--->集合 无论在开发中,在面试中这个知识点都是非常非常重要的,因此,我在此花费的时间也是很多,得参阅挺多的 ...
- java中集合Collection转list对象
参考:java中集合Collection转list对象 首先我的需求是获取到购物车列表,购物车列表是一个Map对象,构造方法获取购物项,这里购物项是Collection对象 // 购物项集合,K商品I ...
- java基础27 单例集合Collection及其常用方法
1.集合 集合是存储对象数据的集合容器 1.1.集合比数组的优势 1.集合可以存储任意类型的数据,数组只能存储同一种数据类型的数据 2.集合的长度是变化的,数组的长度是固定的 1.2.数组:存储 ...
- 18_java之集合Collection
01集合使用的回顾 *A:集合使用的回顾 *a.ArrayList集合存储5个int类型元素 public static void main(String[] args) { ArrayList< ...
- 集合--Collection接口详解&&迭代器
/* * 集合的顶层接口--Collection接口 * 添加 * add() * addAll() * * 遍历集合 * iterator() 迭代器 * * 删除 * remove() * rem ...
随机推荐
- SpringMVC学习笔记 - 第二章 - SSM整合案例 - 技术整合、统一结果封装、统一异常处理、前后联调、拦截器
[前置内容]Spring 学习笔记全系列传送门: Spring学习笔记 - 第一章 - IoC(控制反转).IoC容器.Bean的实例化与生命周期.DI(依赖注入) Spring学习笔记 - 第二章 ...
- HashSet集合介绍-哈希值
HashSet集合介绍 java.util.HashSet是set 接口的一个实现类,它所存储的元素是不可重复的,并且元素都是无序的(即存取顺序不一致).java.util.HashSet底层的实现其 ...
- mybatis-plus 多租户
package com.ruoyi.framework.config; import org.springframework.context.annotation.Bean; import org.s ...
- mysql04-管理mysql常用指令
https://www.runoob.com/mysql/mysql-administration.html 1.常用指令 USE 数据库名 :选择要操作的Mysql数据库,使用该命令后所有Mysql ...
- 一种无损更换iPhone手机铃声方案(无需数据线)
iPhone用户手机铃声更换的方案,现在网上已经很多方法,包括使用某思助手.通过iTunes等进行更换,后者现在在MacOS系统中已经不支持.注意️:此文章针对与MacOS系统与IOS搭配使用.Win ...
- 使用 DirectSound 录制麦克风音频
使用 DirectSound 录制麦克风音频 本文所有代码均可在以下仓库找到 https://gitcode.net/PeaZomboss/learnaudios 目录是demo/dscapture ...
- VMwarestation安装centos系统
上机实验1 1.软硬件准备 软件:推荐使用vmware 镜像:centos7下载网址https://mirror.iscas.ac.cn/centos/7/isos/x86_64/ 这个镜像网址实测比 ...
- SpringMVC的文件、数据校验(Vaildator、Annotation JSR-303)
SpringMvc的文件上传下载: 文件上传 单文件上传 1.底层使用的是Apache fileupload组件进行上传的功能,Springmvc 只是对其进行了封装,简化开发, pom.xml &l ...
- 微信小程序分包
当我们程序太大的时候,打开小程序就会比较慢,此处就需要用到分包加载,按照模块划分不同的包,让用户在需要的时候才加载对用的模块,也就是用户在进入某些页面的时候才下载该页面的资源,提高小程序的打开速度,以 ...
- GIN--HOW POWERFUL GNN
HOW POWERFUL ARE GRAPH NEURAL NETWORKS? 本文是 Jure Leskovec 又一力作,首先对图神经网络的原理做了深入检出.提纲挈领的叙述,然后从原理方面介绍了如 ...