如何使用Comparator比较接口实现ArrayList集合排序

目录
  • 使用Comparator比较接口实现排序
    • Comparator接口定义如下
    • 我们定义一个“person”类
    • 创建按年龄排序的比较器实现Comparator接口
    • 使用ArrayList进行排序测试
    • 以名字长度排序的Comparator比较器
  • 总结

使用Comparator比较接口实现排序

Comparator是比较接口,当我们需要对某个类进行排序而此类本身没有时Comparable时,我们可以建立一个该类的比较器来实现Comparator接口即可实现排序。

Comparator接口定义如下

	public interface Comparator<T>{
		int compara(T o1 ,T o2);
		boolean equals(Object obj);
	}

备注:若实现Comparator接口,必须实现compara(T o1,To2)函数,但可以不实现equals函数。

例子:

我们定义一个“person”类

	public class person {

	private String name;  //姓名
	private int age;	  //年纪

	//构造函数
	public person(String get_name , int get_age) {
		this.name = get_name;
		this.age = get_age;
	}

	public int get_age() {
		return this.age;
	}

	public String get_name() {
		return this.name;
	}

}

创建按年龄排序的比较器实现Comparator接口

	//创建根据年龄排序的比较器
	public class compare_byAge implements Comparator<person> {

			//重写compare方法
			@Override

			//此处为按年龄升序排序
			public int compare(person o1, person o2) {
				if(o1.get_age() > o2.get_age() ) {
					return 1;
				}
				else if(o1.get_age() == o2.get_age()) {
					return 0;
				}
				else {
					return -1;
				}
			}

	}

使用ArrayList进行排序测试

	public class test {

	public static void main(String[] args) {

		//创建person对象
		person p1 = new person("li",15);
		person p2 = new person("ping",18);
		person p3 = new person("liao",13);
		person p4 = new person("long",23);
		person p5 = new person("xu",12);

		//创建peson类的ArrayList集合
		ArrayList<person> per = new ArrayList<person>();

		//将实例化的person对象加入到ArrayList集合中
		per.add(p1);
		per.add(p2);
		per.add(p3);
		per.add(p4);
		per.add(p5);

		//排序前的顺序(其实就是按照插入顺序)
		System.out.println("排序前:");
		for(int i =0;i<per.size();i++) {
			System.out.println(per.get(i).get_age()+"	"+per.get(i).get_name());
		}

		System.out.println();

		//用Collection.sort()排序
		Collections.sort(per,new compare_byAge());

		System.out.println("排序后:");
		for(int i =0;i<per.size();i++) {
			System.out.println(per.get(i).get_age()+"	"+per.get(i).get_name());
		}
	}

}

输出结果:

以名字长度排序的Comparator比较器

	//设置以名字长度为判断标准的比较器
	public class compare_bynameLen implements Comparator<person> {

	public int compare(person o1, person o2) {

		//按名字长度升序排序
		if(o1.get_name().length() > o2.get_name().length()) {

			return 1;      

		}

		//名字长度相同的情况下按照年龄升序排序
		else if( o1.get_name().length() == o2.get_name().length() ) {
			if(o1.get_age() > o2.get_age() ) {
				return 1;
			}
			else if(o1.get_age() == o2.get_age()) {
				return 0;
			}
			else {
				return -1;
			}
		}

		else {
			return -1;
		}

	}
}

运行结果为:

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持我们。

(0)

相关推荐

  • Java使用Collections.sort()排序的方法

    Java中Collections.sort()的使用 在日常开发中,很多时候都需要对一些数据进行排序的操作.然而那些数据一般都是放在一个集合中如:Map ,Set ,List 等集合中.他们都提共了一个排序方法 sort(),要对数据排序直接使用这个方法就行,但是要保证集合中的对象是 可比较的. 怎么让一个对象是 可比较的,那就需要该对象实现 Comparable<T> 接口啦.然后重写里面的 compareTo()方法.我们可以看到Java中很多类都是实现类这个接口的 如:Integer,L

  • Java集合排序规则接口Comparator用法解析

    1. 前言 最近用到了集合排序(基于 Java 8).现在我能用 Stream 的就用 Stream ,真香!排序可以这么写: List<People> peoples = new ArrayList<>(); // 中间省略 // 按照年龄从小到大排序 peoples.sort(Comparator.comparing(People::getAge)); 这里排序用到了一个关键接口 java.util.Comparator.排序比较作为业务中经常出现的需求,我们有必要研究一下这个

  • 对比Java中的Comparable排序接口和Comparator比较器接口

    Comparable Comparable 是排序接口. 若一个类实现了Comparable接口,就意味着"该类支持排序". 即然实现Comparable接口的类支持排序,假设现在存在"实现Comparable接口的类的对象的List列表(或数组)",则该List列表(或数组)可以通过 Collections.sort(或 Arrays.sort)进行排序. 此外,"实现Comparable接口的类的对象"可以用作"有序映射(如Tree

  • Java8 Comparator排序方法实例详解

    这篇文章主要介绍了Java8 Comparator排序方法实例详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 Java8 中 Comparator 接口提供了一些静态方法,可以方便于我们进行排序操作,下面通过例子讲解下如何使用 对整数列表排序(升序) List<Integer> list = Arrays.asList(1, 4, 2, 6, 2, 8); list.sort(Comparator.naturalOrder()); Sys

  • 如何使用Comparator比较接口实现ArrayList集合排序

    目录 使用Comparator比较接口实现排序 Comparator接口定义如下 我们定义一个“person”类 创建按年龄排序的比较器实现Comparator接口 使用ArrayList进行排序测试 以名字长度排序的Comparator比较器 总结 使用Comparator比较接口实现排序 Comparator是比较接口,当我们需要对某个类进行排序而此类本身没有时Comparable时,我们可以建立一个该类的比较器来实现Comparator接口即可实现排序. Comparator接口定义如下

  • Java中ArrayList集合的常用方法大全

    ArrayList集合的创建 非泛型 创建ArrayList集合对象,可以添加任意Object子类元素至集合 //非泛型创建的ArrayList集合对象可以保存任何类型的值 ArrayList list = new ArrayList(); list.add("str");//存入String类型数据 list.add(23);//存入int类型数据 list.add(2.5);//存入double类型数据 list.add('c');//存入char类型数据 泛型 采用泛型创建Arr

  • Java Iterator接口遍历单列集合迭代器原理详解

    这篇文章主要介绍了Java Iterator接口遍历单列集合迭代器原理详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 Iterator接口概述 在程序开发中,经常需要遍历集合中的所有元素.针对这种需求,JDK专门提供了一个接口java.util.Iterator . Iterator 接口也是Java集合中的一员,但它与 Collection . Map 接口有所不同,Collection 接口与 Map 接口主要用于存储元素,而 Iter

  • 在java中ArrayList集合底层的扩容原理

    第一章 前言概述 第01节 概述 底层说明 ArrayList是List的实现类,它的底层是用Object数组存储,线程不安全 后期应用 适合用于频繁的查询工作,因为底层是数组,可以快速通过数组下标进行查找 第02节 区别 区别方向 ArrayList集合 LinkedList集合 线程安全 不安全 不安全 底层原理 Object类型数组 双向链表 随机访问 支持(实现 RandomAccess接口) 不支持 内存占用 ArrayList 浪费空间, 底层是数组,末尾预留一部分容量空间 Link

  • C#检查指定对象是否存在于ArrayList集合中的方法

    本文实例讲述了C#检查指定对象是否存在于ArrayList集合中的方法.分享给大家供大家参考.具体分析如下: C#的ArrayList提供了一个专用的Contains方法来检测ArrayList是否包含指定的对象,返回值是一个bool类型 ArrayList alcollect = new ArrayList(); // Add individual items to the collection string str = "learn csharp"; alcollect.Add(s

  • Java ArrayList集合详解(Java动态数组)

    目录 一.ArrayList集合的概述和基本使用 1.概述 2.基本使用 二.ArrayList集合的详细介绍 1.定义一个ArrayList集合 2.ArrayList集合常用的方法 3.将"类"存入ArrayList集合 4.遍历ArrayList集合 5.将基本数据类型存入ArrayList集合 6.ArrayList作为方法的参数 7.ArrayList作为方法的返回值 一.ArrayList集合的概述和基本使用 1.概述 ArrayList是集合的一种实现,Collectio

  • Java常用工具类—集合排序

    一.集合排序概述 1.主要内容 集合中的基本数据类型排序 集合中的字符串排序 Comparator接口 Comparable接口 回顾: //数组的排序 int[] arr= {2,3,4,5,2,1}; Arrays.sort(arr); 2.集合排序方法 使用Collections类的sort(List list)方法 sort(List list)是根据元素的自然顺序对指定列表按升序进行排序. 二.对基本数据类型和字符串类型进行排序 1.对基本数据类型排序 List中只能存放对象,要想存放

  • Java sort集合排序的两种方式解析

    这篇文章主要介绍了Java sort集合排序的两种方式解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 Comparable和Comparator public static <T> void sort(List<T> list); 将集合中的数据按照默认规则进行排序 (我们在自己的类里面实现Comparabl接口方法compareTo) public static <T> void sort(List<T&g

随机推荐