首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >java集合进行排序的两种方式

java集合进行排序的两种方式

作者头像
全栈程序员站长
发布于 2022-08-09 07:18:03
发布于 2022-08-09 07:18:03
50800
代码可运行
举报
运行总次数:0
代码可运行

大家好,又见面了,我是你们的朋友全栈君。

java集合的工具类Collections中提供了两种排序的方法,分别是:

  1. Collections.sort(List list)
  2. Collections.sort(List list,Comparator c)

第一种称为自然排序,参与排序的对象需实现comparable接口,重写其compareTo()方法,方法体中实现对象的比较大小规则,示例如下: 实体类:(基本属性,getter/setter方法,有参无参构造方法,toString方法)

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
package com.zgljl2012.activemq.example1;

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

public class Emp implements Comparable<Object>{
	 private String name;
	    private int age;
	    public String getName() {
	        return name;
	    }
	    public void setName(String name) {
	        this.name = name;
	    }
	    public int getAge() {
	        return age;
	    }
	    public void setAge(int age) {
	        this.age = age;
	    }
	    public Emp() {
	        super();
	    }
	    public Emp(String name, int age) {
	        super();
	        this.name = name;
	        this.age = age;
	    }
	    @Override
	    public String toString() {
	        return "Emp [name=" + name + ", age=" + age + "]";
	    }
	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		List list = new ArrayList();
		 list.add(new Emp("tom",18));
	        list.add(new Emp("jack",20));
	        list.add(new Emp("rose",15));
	        list.add(new Emp("jerry",17));
	        System.out.println("排序前:");
	        for(Object o : list){
	            System.out.println(o);
	        }
	        System.out.println("排序后:");
	        Collections.sort(list);
	        for(Object o : list){
	            System.out.println(o);
	        }

	}

	public int compareTo(Object o) {
		// TODO Auto-generated method stub
		if(o instanceof Emp){
			Emp emp=(Emp) o;
//			return this.name-emp.name;//按姓名排序
			return this.age-emp.age;//按年龄排序
		}
		return age;
	}

}

结果:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
排序前:
Emp [name=tom, age=18]
Emp [name=jack, age=20]
Emp [name=rose, age=15]
Emp [name=jerry, age=17]
排序后:
Emp [name=rose, age=15]
Emp [name=jerry, age=17]
Emp [name=tom, age=18]
Emp [name=jack, age=20]

第二种叫定制排序,或自定义排序,需编写匿名内部类,先new一个Comparator接口的比较器对象c,同时实现compare()其方法; 然后将比较器对象c传给Collections.sort()方法的参数列表中,实现排序功能;

说明:第一种方法不够灵活,实体类实现了comparable接口后,会增加耦合,如果在项目中不同的位置需要根据不同的属性调用排序方法时,需要反复修改比较规则(按name还是按age),二者只能选择其一,会起冲突.第二种就很好地解决了这个问题.在需要的地方,创建个内部类的实例,重写其比较方法即可.

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
package com.zgljl2012.activemq.example1;

import java.util.ArrayList;
import java.util.Collection;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
import java.util.function.Function;
import java.util.function.ToDoubleFunction;
import java.util.function.ToIntFunction;
import java.util.function.ToLongFunction;

import org.junit.Test;

public class test {
	
	@Test
	public void comparatorSortAge(){
		List list = new ArrayList();
		 list.add(new Emp("tom",18));
	        list.add(new Emp("jack",20));
	        list.add(new Emp("rose",15));
	        list.add(new Emp("jerry",17));
	        System.out.println("排序前:");
	        for(Object o : list){
	            System.out.println(o);
	        }
		Collections.sort(list, new Comparator() {

			public int compare(Object o1, Object o2) {
				// TODO Auto-generated method stub
				if(o1 instanceof Emp && o2 instanceof Emp){
					Emp emp1=(Emp)o1;
					Emp emp2=(Emp)o2;
					return emp1.getAge()-emp2. getAge();
				}
				throw new ClassCastException("不能转换成Emp类型");
			}
		});
		System.out.println("排序后:");
        for(Object o : list){
            System.out.println(o);
        }
	}

}

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/106050.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年4月2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
集合工具类Collections指南,以及Comparable和Comparator排序详解
文章目录 🍟常用功能 🍕Comparator比较器 🌭Comparable和Comparator两个接口的区别 🥪练习 🌮扩展 🍟常用功能 java.utils.Collections是集合工具类
共饮一杯无
2022/11/28
3390
Java集合详解(超详细)
(2)ArrayList(int initialCapacity)构造一个具有指定初始容量的空列表。
全栈程序员站长
2022/09/01
1K0
Java集合详解(超详细)
Java基础(十九):集合框架
List除了从Collection集合继承的方法外,List 集合里添加了一些根据索引来操作集合元素的方法
Java微观世界
2025/01/21
5960
Java基础(十九):集合框架
java之操作集合的工具类--Collections
Collections中提供了大量方法对集合元素进行排序、查询和修改等操作,还提供了对集合对象设置不可变、对集合对象实现同步控制等方法。
西西嘛呦
2020/08/26
4030
【Java】List、Set、数据结构、Collections
当你用着java里面的容器类很爽的时候,你有没有想过,怎么ArrayList就像一个无限扩充的数组,也好像链表之类的。好用吗?好用,这就是数据结构的用处,只不过你在不知不觉中使用了。
陶然同学
2023/02/27
5040
【Java】List、Set、数据结构、Collections
Java Collection与Map详解
所有实现了Collection接口的集合类都有一个iterator()方法,用以返回一个实现了lterator接口的对象,即可以返回一个迭代器。
timerring
2023/05/03
1.4K0
Java Collection与Map详解
浅谈Comparable与Comparator的区别
平时进行自定义排序一直使用实现Comparable接口,一段时间后操作的时候居然发现有了个Comparator接口
陈灬大灬海
2022/11/28
3630
浅谈Comparable与Comparator的区别
java集合的遍历和排序(五)
如果您希望以不同的方式对Java集合进行排序,例如按长度、字母顺序等,则可以使用Java集合框架中的“Comparator”接口。Comparator接口提供了一种自定义排序集合的方法,您可以使用以下步骤自定义Java集合的排序方式:
玖叁叁
2023/05/08
3260
Java源码系列(1):Comparable和Comparator的区别
在讲Comparable和Comparator区别之前,先补充一个知识点。 先看代码: Person类
陈琛
2020/06/12
4380
Java源码系列(1):Comparable和Comparator的区别
Comparable 与 Comparator 浅析
来源:朱小厮, blog.csdn.net/u013256816/article/details/50899416 今天博主在翻阅TreeMap的源码,发现其键必须是实现Comparable或者Comparator的接口时产生了一些兴趣,比如在TreeMap中的put方法分别对Comparable和Comparator接口分别进行处理。那么疑问就来了,Comparable和Comparator接口的区别是什么,Java中为什么会存在两个类似的接口? Comparable和Comparator接口都是用来比较
用户1257393
2018/01/30
6620
Java中list<Object[]>、list<Student>、list<Map<String,String>>排序
1:list<Object[]>的排序 public static void main(String[] args) { // TODO Auto-generated method stub Object[] o1=new Object[4]; o1[0]="5"; o1[1]="o1"; o1[2]="o11"; o1[3]="o111"; Object[] o2=new Object[4]; o2[0]="3"; o2[1]="o2"; o2[2]="o22"; o2[3]="o
cMusketeer
2018/03/28
3.9K0
Java中list<Object[]>、list<Student>、list<Map<String,String>>排序
10.TreeSet、比较器
Comparable和Comparator  Comparable 简介 Comparable 是排序接口。 若一个类实现了Comparable接口,就意味着“该类支持排序”。  即然实现Comparable接口的类支持排序,假设现在存在“实现Comparable接口的类的对象的List列表(或数组)”,则该List列表(或数组)可以通过 Collections.sort(或 Arrays.sort)进行排序。 此外,“实现Comparable接口的类的对象”可以用作“有序映射(如TreeMap)”中的键或
六月的雨
2018/05/14
1.1K0
Java基础之集合
-集合结构只要发生改变,迭代器必须重新获取,如果还是用的之前的迭代器,就会出现异常java.util.ConcurrentModificationException
shaoshaossm
2022/12/27
5730
Java基础之集合
Java类排序
今天上课,老师讲到Arrays.sor()的时候说,这个可以对数组进行排序,于是当时脑海中立刻浮现出两个问题:一、如果对类排序,一定要把实现什么接口。二、实现了这个接口,Java怎么知道一个类是否实现了某个接口。于是带着这个问题做了一翻查找。
SingYi
2022/07/13
7720
Collections.sort的两种用法
Collections是一个工具类,sort是其中的静态方法,是用来对List类型进行排序的,它有两种参数形式:
Java架构师必看
2021/11/29
8250
Collections.sort的两种用法
Java集合分类以及各自特点
常用的就是ArrayList,LinkedList,HashSet,LinkedHashSet,TreeSet,HashMap,LinkedHashMap,TreeMap; 数组和集合的区别 区别1: 数组可以存储基本数据类型/引用数据类型 基本数据类型存的是值 引用数据类型存的是地址 数组在创建的时候 就会定义存储的数据类型 也就是只能存储一种数据类型 集合只能存储引用数据类型(对象) 集合中也可以存储基本数据类型(装箱)最终存储的还是 Object 如果没有泛型限定 默认存储的都是 Object类型的数据 也就是任意类型 区别2 数组长度是固定的,不能自动增长 集合是长度可变的,根据元素的多少来决定长度
全栈程序员站长
2022/09/01
6150
Java-集合
哈喽!大家好,我是小简。今天开始学习《Java-集合》,此系列是我做的一个 “Java 从 0 到 1 ” 实验,给自己一年左右时间,按照我自己总结的 Java-学习路线,从 0 开始学 Java 知识,并不定期更新所学笔记,期待一年后的蜕变吧!<有同样想法的小伙伴,可以联系我一起交流学习哦!>
小简
2023/01/04
1.4K0
Java-集合
java进阶|比较器Comparable和Comparator
一,可能对于java的coder来说,这个点很简单,但对于我来说又是很难,想写这篇文章也是很久了,今天就以自己的理解来看下这两个接口,首先我们先看下Comparable接口的结构图。
码农王同学
2020/07/06
7840
java中List对象列表去重或取出以及排序
面试碰到几次list的去重和排序。下面介绍一种做法: 1. list去重 1.1 实体类Student List<Student>容量10k以上,要求去重复。这里Student的重复标准是属性相同,因此需要重写equals和hashcode方法,不知道有几个可以手写出来。 student的equals方法: public void equals(Object o){ if(this == o) retun true; if(!(o instanceof Student)) return false;
Ryan-Miao
2018/03/13
4.5K0
Java学习笔记(三):集合类与常用数据结构的典型用法
foochane :https://foochane.cn/article/2019122801.html 1 Collection集合 1.1 集合概述 在前面基础班我们已经学习过并使用过集合A
foochane
2020/02/13
9670
相关推荐
集合工具类Collections指南,以及Comparable和Comparator排序详解
更多 >
领券
一站式MCP教程库,解锁AI应用新玩法
涵盖代码开发、场景应用、自动测试全流程,助你从零构建专属AI助手
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验