集合(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 ...
随机推荐
- 轻松理解Promise.all 、Promise.then、Promise.race有什么区别以及使用方法
简单来说呢,Promse.all一般应用于某个场景需要多个接口数据合并起来才能实现 有个极大地好处我必须说一下,请求顺序和获取数据顺序是一样的哟,大可放心使用~~ const success1 = n ...
- linux基础(部分讲解)
linux常见岗位 Linux运维工程师.Linux高级架构师.运维开发工程师.数据库管理员.云计算架构师 作为python后端可以从事的linux岗位: 自动化运维.容器运维.DBA 注意:会的越多 ...
- 在腾讯云上创建一个玩具docker-mysql数据服务
有时候开发需求会自己做一下测试数据,在自己电脑本地安装的服务多了电脑环境会搞的很乱,这时使用云服务器安装个docker服务是一个不错的寻找. 下面步骤是在腾讯云上安装docker-mysql镜像,并导 ...
- 我们从 CircleCI 安全事件获得的3个经验教训
CircleCI 作为业内最受欢迎的 CI/CD 平台提供商之一,有超过20万个 DevOps 团队使用其平台.该公司在今年1月在其官网报告了一起安全事件引起客户恐慌.在此事件中,有身份不明的恶意攻击 ...
- allure环境搭建
allure环境搭建 在搭建之前你应该有python.pycharm jdk也需要(文中忽略,可以参考网上文档安装,可以用jdk1.8) 以windows为例,mac.linux你用到这些操作系统,这 ...
- DBSCAN学习笔记
基本概念 核心点:若某个点的密度达到算法设定的阈值,即ε-邻域内点的数量(包括自己)不小于minPts,则该点为核心点. 边界点:在ε-邻域内点的数量小于minPts,但是落在核心点邻域内的点. 噪声 ...
- Windows 10 企业版 LSTC 激活秘钥及方法
Windows 10 企业版 LSTC 秘钥:M7XTQ-FN8P6-TTKYV-9D4CC-J462D 同时按下Win键+X,然后选择Windows PowerShell(管理员)按顺序输入下面的字 ...
- BAL数据集详解
详细格式:https://grail.cs.washington.edu/projects/bal/ Bundle Adjustment in the Large Recent work in Str ...
- Vue3
VUE.3 1.前端工程化: 小白视角 会写HTML. css.JavaScript就会前端开发 需要美化页面的样式,就拽一个bootstrap来 需要操作DOM或者发起Ajax请求,就再拽一个Jqu ...
- css当文字过长时,显示省略号
/* 省略号三属性 */ /* 强制不换行 */ white-space: nowrap; /* 溢出隐藏 */ overflow: hidden; /* 省略号 */ text-overflow: ...