【java学习—十】操作集合的工具类Collections(8)

文章目录

  • 1. 操作集合的工具类: Collections
  • 2. 应用
  • 3. 查找、替换
  • 3.1. max 与 min
    • 3.2. 根据Comparator返回max(min)
  • 3.3. frequency 与 replaceAll
  • 4. 同步控制


1. 操作集合的工具类: Collections

    Collections 是一个操作 SetListMap 等集合的工具类
    Collections 中提供了大量方法对集合元素进行排序、查询和修改等操作,还提供了对集合对象设置不可变、对集合对象实现同步控制等方法。
    
排序操作:
    • reverse(List) :反转 List 中元素的顺序
    • shuffle(List) :对 List 集合元素进行随机排序
    • sort(List) :根据元素的自然顺序对指定 List 集合元素按升序排序
    • sort(List, Comparator) :根据指定的 Comparator 产生的顺序对 List集合元素进行排序
    • swap(List, int , int) :将指定 list 集合中的 i 处元素和 j 处元素进行交换

2. 应用

举例1:

package day10;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

public class Test7 {
	public static void main(String[] args) {
		List<String> list = new ArrayList<String>();
		
		list.add("b");
		list.add("cd");
		list.add("ca");
		list.add("a");
		list.add("1");
		
		System.out.println(list);
		Collections.reverse(list);//反转List中元素的顺序
		System.out.println(list);
		
		Collections.shuffle(list);//对List集合进行随机排序
		System.out.println(list);
		
		Collections.sort(list);//list集合以字典升序排列
		System.out.println(list);
		
	}
}

运行结果:

在这里插入图片描述

举例2:

package day10;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

public class Test7 {
	public static void main(String[] args) {

		Student s1 = new Student(14, "张三");
		Student s2 = new Student(12, "李四");
		Student s3 = new Student(13, "王五");
		Student s4 = new Student(11, "杨六");
		
		List<Student> stus = new ArrayList<Student>();
		stus.add(s1);
		stus.add(s2);
		stus.add(s3);
		stus.add(s4);
		
		for(Student stu : stus) {
			System.out.println(stu.name + "," + stu.age);
		}
		
		System.out.println("----------------------------------");
		//根据元素的自然顺序对指定 List 集合元素按升序排序
		Collections.sort(stus, new Student());
		for(Student stu : stus) {
			System.out.println(stu.name + "," + stu.age);
		}
	
	}

}

class Student implements Comparator<Student>{
	int age;
	String name;
	
	public Student() {
		
	}
	
	public Student(int age, String nmae) {
		this.age = age;
		this.name = nmae;
	}
	
	@Override
	public int compare(Student o1, Student o2) {//根据年龄升序排列对象
		if(o1.age > o2.age) {
			return 1;
		}else if(o1.age < o2.age) {
			return -1;
		}else {
			return 0;
		}
	}
	
}

运行结果:
在这里插入图片描述

举例3:将指定 list 集合中的 i 处元素和 j 处元素进行交换

package day10;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

public class Test7 {
	public static void main(String[] args) {
		List<String> list = new ArrayList<String>();
		
		list.add("b");
		list.add("cd");
		list.add("ca");
		list.add("a");
		list.add("1");
		
		System.out.println(list);
		Collections.reverse(list);//反转List中元素的顺序
		System.out.println(list);
		
		Collections.shuffle(list);//对List集合进行随机排序
		System.out.println(list);
		
		Collections.sort(list);//list集合以字典升序排列
		System.out.println(list);
		
		Collections.swap(list, 0, 4);//将指定 list 集合中的 i 处元素和 j 处元素进行交换
		System.out.println(list);	
		
	}

}

运行结果:

在这里插入图片描述

3. 查找、替换

3.1. max 与 min

    Object max(Collection):根据元素的自然顺序,返回给定集合中的最大元素
    Object min(Collection):根据元素的自然顺序,返回给定集合中的最小元素

举例:

package day10;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

public class Test7 {
	public static void main(String[] args) {
		List<String> list = new ArrayList<String>();
		
		list.add("b");
		list.add("cd");
		list.add("ca");
		list.add("a");
		list.add("1");
		
		System.out.println(list);
		Collections.reverse(list);//反转List中元素的顺序
		System.out.println(list);
		Collections.shuffle(list);//对List集合进行随机排序
		System.out.println(list);
		Collections.sort(list);//list集合以字典升序排列
		System.out.println(list);
		
		System.out.println(Collections.max(list));//根据元素的自然顺序,返回给定集合中的最大元素
		System.out.println(Collections.min(list));//根据元素的自然顺序,返回给定集合中的最小元素
	
	}

}

运行结果:
在这里插入图片描述

3.2. 根据Comparator返回max(min)

    Object max(Collection , Comparator) :根据 Comparator 指定的顺序,返回给定集合中的最大元素
    Object min(Collection , Comparator):根据 Comparator 指定的顺序,返回给定集合中的最小元素

举例:

package day10;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

public class Test7 {
	public static void main(String[] args) {

		Student s1 = new Student(14, "张三");
		Student s2 = new Student(12, "李四");
		Student s3 = new Student(13, "王五");
		Student s4 = new Student(11, "杨六");
		
		List<Student> stus = new ArrayList<Student>();
		stus.add(s1);
		stus.add(s2);
		stus.add(s3);
		stus.add(s4);
		
		//根据 Comparator 指定的顺序,返回给定集合中的最大元素
		Student s = Collections.max(stus, new Student());
		System.out.println(s.name + "," + s.age);
		
		//根据 Comparator 指定的顺序,返回给定集合中的最小元素
		Student ss = Collections.min(stus, new Student());
		System.out.println(ss.name + "," + ss.age);

	}
}

class Student implements Comparator<Student>{
	int age;
	String name;
	
	public Student() {
		
	}
	
	public Student(int age, String nmae) {
		this.age = age;
		this.name = nmae;
	}
	
	@Override
	public int compare(Student o1, Student o2) {//根据年龄升序排列对象
		if(o1.age > o2.age) {
			return 1;
		}else if(o1.age < o2.age) {
			return -1;
		}else {
			return 0;
		}
	}
}

运行结果:
在这里插入图片描述

3.3. frequency 与 replaceAll

    int frequency(Collection , Object) :返回指定集合中指定元素的出现次数
    boolean replaceAll(List list , Object oldVal , Object newVal) :使用新值替换 List 对象的所有旧值

package day10;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;

public class Test7 {
	public static void main(String[] args) {
		List<String> list = new ArrayList<String>();
		
		list.add("b");
		list.add("cd");
		list.add("ca");
		list.add("a");
		list.add("1");
		list.add("a");
		
		//返回指定集合中指定元素的出现次数
		System.out.println(Collections.frequency(list, "a"));
		System.out.println(Collections.frequency(list, "b"));
		System.out.println(Collections.frequency(list, "x"));
		
		//使用新值替换List对象的所有旧值
		Collections.replaceAll(list, "a", "aa");
		System.out.println(list);
	
	}
}

运行结果:
在这里插入图片描述

4. 同步控制

这部分了解即可

    Collections 类中提供了多个 synchronizedXxx() 方法,该方法可使将指定集合包装成线程同步的集合,从而可以解决多线程并发访问集合时的线程安全问题

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/111971.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

揭示沉浸式展览设计方案中的创新展示技术

随着数字多媒体技术在展览设计方案中的广泛应用&#xff0c;让传统的静态展示方式&#xff0c;走向了更为生动、立体的动态化设计模式&#xff0c;而其中最令人瞩目的当属沉浸式展览展示&#xff0c;它以其独特的展示方式和引人入胜的体验效果&#xff0c;引发了大量的关注和热…

解决找不到msvcr120.dll无法继续执行问题的5个方法,快速解决dll问题

在计算机使用过程中&#xff0c;我们经常会遇到一些错误提示&#xff0c;其中之一就是找不到msvcr120.dll的错误。这个错误通常发生在运行某些程序或游戏时&#xff0c;它会导致程序无法正常启动或运行。那么&#xff0c;如何解决找不到msvcr120.dll的问题呢&#xff1f;下面我…

深度学习数据集大合集—疾病、植物、汽车等

最近又收集了一大批深度学习数据集&#xff0c;今天分享给大家&#xff01;废话不多说&#xff0c;直接上数据&#xff01; 1、招聘欺诈数据集 招聘欺诈数据集&#xff1a;共收集了 200,000 条数据&#xff0c;来自三个网站。 该数据集共收集了 200.000 条数据&#xff0c;分别…

HackTheBox-Starting Point--Tier 1---Tactics

文章目录 一 题目二 实验过程三 Psexec工具使用 一 题目 Tags Network、Protocols、SMB、Reconnaissance、Misconfiguration译文&#xff1a;网络、协议、中小企业、侦察、配置错误Connect To attack the target machine, you must be on the same network.Connect to the S…

自动化测试实战篇:UI自动化测试用例管理平台搭建

用到的工具&#xff1a;python3 django2 mysql RabbitMQ celery selenium python3和selenium这个网上很多教程&#xff0c;我不在这一一说明&#xff1b; 平台功能介绍&#xff1a; 项目管理&#xff1a;用于管理项目。每个项目可以设置多个环境&#xff0c;例如开发环境…

怎样才知道一个单片机的性能到极限了?

怎样才知道一个单片机的性能到极限了&#xff1f; 就题主的问题&#xff0c;应该是想问CPU利用率的问题。可以看看Rt-thread中关于统计CPU利用率函数&#xff0c;其主要实现方式是在idle线程先关闭中断计数后&#xff0c;正常计数(可被其他线程打断)&#xff0c;最近很多小伙伴…

竞赛知识点11【线段树】

文章目录 一、概念二、基本操作2.1、建树2.2、区间询问操作2.3、单点修改2.4、区间修改一、概念 线段树是用一种树状结构来存储一个连续区间的信息的数据结构。 它主要用于处理一段连续区间的插入,查找,统计,查询等操作。 复杂度: 设区间长度是 n n n,所有操作的复杂度是 l…

java修仙基石篇->instanceof子父类检查

instanceof检查子父类&#xff08;或者是否能被强转&#xff09; 作用1&#xff1a;检查某对象是否是某类的子类 如&#xff1a;儿子类继承了父亲类。 检查儿子类对象是否属于父亲类 作用2&#xff1a;检查两个对象是否可以强转 语法&#xff1a; 子类对象 instanceof 父…

蚂蚁蚁盾发布实体产业「知识交互建模引擎」,最快10分钟定制AI风控模型

数字化起步晚、数据分散稀疏、专业壁垒高、行业知识依赖「老师傅」&#xff0c;是很多传统产业智能化发展面临的难题。2023年云栖大会上&#xff0c;蚂蚁集团安全科技品牌蚁盾发布“知识交互建模引擎”&#xff0c;将实体产业知识与AI模型有机结合&#xff0c;助力企业最快10分…

【23真题】Top3简单专业课似双非!

今天分享的是23年复旦大学957的信号与系统试题及解析。 本套试卷难度分析&#xff1a;这套卷子平均分为120左右&#xff0c;最高分145分。22年复旦大学957信号与系统&#xff0c;我也发布过&#xff0c;若有需要戳这里自取&#xff01;本套试题内容难度中等偏下&#xff0c;说…

主播直播美颜SDK:性能优化策略

当下&#xff0c;主播直播美颜SDK成为了越来越多主播的利器。这些SDK可以实时美化主播的外貌&#xff0c;提高视觉吸引力&#xff0c;但同时也需要处理大量的图像数据。因此&#xff0c;性能优化成为了不可或缺的一环。本文将探讨主播直播美颜SDK的性能优化策略&#xff0c;以确…

【详细教程】关于如何使用GitGitHub的基本操作汇总GitHub的密钥配置 ->(个人学习记录笔记)

文章目录 1. Git使用篇1.1 下载安装Git1.2 使用Git 2. GitHub使用篇2.1 如何git与GitHub建立联系呢&#xff1f;2.2 配置公钥 1. Git使用篇 1.1 下载安装Git 点击 官网链接 后&#xff0c;进入Git官网&#xff0c;下载安装包 然后根据系统类型进行下载&#xff0c;一般为wind…

如何修改MinIO Share时的URL

使用Helm方式在Kubernetes中部署MinIO后。选择分享文件&#xff0c;获得的分享连接域名为K8S内部Service连接地址&#xff0c;这样的地址不可以在集群外部使用。 修改MINIO_SERVER_URL 前置条件 &#xff08;Helm部署方式&#xff09;域名需要访问到Name为minio的K8S Service…

ReuseAndDiffuse笔记

https://arxiv.org/pdf/2309.03549.pdf https://mp.weixin.qq.com/s/pbSK4KOO2hqQU1-uwQzjBA 数据集&#xff1a; BLIP-2、MiniGPT4 等多模态大语言模型,对Moments-In-Time、Kinetics-700 和 VideoLT等数据集进行自动标注&#xff1b; Image-text datasets&#xff1a;平移缩…

《低代码指南》——维格云机器人常见报错怎么解决?

在使用维格机器人调用维格表的API过程中,可能会出现机器人执行结果未达到预期的情况,此时可能是机器人运行出现了问题;通过点击这个机器人右上角的“运行历史”可以查看运行记录,通过对运行记录的分析,可以推断出问题所在,然后进行修改。 而对于运行历史的分析,主要是针…

C语言——判断 101-200 之间有多少个素数,并输出所有素数

完整代码&#xff1a; // 判断 101-200 之间有多少个素数&#xff0c;并输出所有素数 #include<stdio.h>//判断一个数n是否为素数 int isPrimeNumber(int n){//1不是素数if (n1){return 0;}for (int i 2; i <(n/2); i){//当有n能被整除时&#xff0c;不是素数if ((n…

【ES专题】ElasticSearch 高级查询语法Query DSL实战

目录 前言阅读对象阅读导航前置知识数据准备笔记正文一、ES高级查询Query DSL1.1 基本介绍1.2 简单查询之——match-all&#xff08;匹配所有&#xff09;1.2.1 返回源数据_source1.2.2 返回指定条数size1.2.3 分页查询from&size1.2.4 指定字段排序sort 1.3 简单查询之——…

LTD249次升级 | 官微名片可编辑微信二维码 • 商城可图标展示商品分类 • 应用引擎改进导入功能、可批量导入图片文件

1、 官微名片支持编辑微信二维码、传真号等&#xff1b; 2、 新增商城分类列表功能页&#xff1b; 3、 应用引擎支持图片字段批量导入&#xff1b; 4、 官微中心功能优化&#xff1b; 5、 已知问题修复与优化&#xff1b; 01 官微名片(平台版) 1) 首页布局与样式优化 在本次…

树结构及其算法-二叉树遍历

目录 树结构及其算法-二叉树遍历 一、中序遍历 二、后序遍历 三、前序遍历 C代码 树结构及其算法-二叉树遍历 我们知道线性数组或链表都只能单向从头至尾遍历或反向遍历。所谓二叉树的遍历&#xff08;Binary Tree Traversal&#xff09;&#xff0c;简单的说法就是访问树…

轧钢厂安全生产方案:AI视频识别安全风险智能监管平台的设计

一、背景与需求 轧钢厂一般都使用打包机对线材进行打包作业&#xff0c;由于生产需要&#xff0c;人员需频繁进入打包机内作业&#xff0c;如&#xff1a;加护垫、整包、打包机检修、调试等作业。在轧钢厂生产过程中&#xff0c;每个班次生产线材超过300件&#xff0c;人员在一…