java 比较器 对多个对象进行排序操作

1. Comparator 和 Comparable 相同的地方

他们都是java的一个接口, 并且是用来对自定义的class比较大小的,

什么是自定义class: 如 public class Person{ String name; int age }.

当我们有这么一个person数组时,里面包含了person1, person2, persion3....., 我们用Collections.sort( person ), 
是得不到预期的结果的. 这时肯定有人要问, 那为什么可以排序一个字符串数组呢呢:

如 Person[] person={"hello1" , "hello3" , "hello2"}, Collections.sort( person) 能够得到正确的排序, 那是因为 
String 这个对象已经帮我们实现了 Comparable接口 , 所以我们的 Person 如果想排序, 也要实现一个比较器。

2. Comparator 和 Comparable 的区别

Comparable

Comparable 定义在 Person类的内部:

public class Persion implements Comparable {..比较Person的大小..},

因为已经实现了比较器,那么我们的Person现在是一个可以比较大小的对象了,它的比较功能和String完全一样,可以随时随地的拿来
比较大小,因为Person现在自身就是有大小之分的。Collections.sort(person)可以得到正确的结果。

Comparator

Comparator 是定义在Person的外部的, 此时我们的Person类的结构不需要有任何变化,如

public class Person{ String name; int age },

然后我们另外定义一个比较器:

public MyCompartor implements Comparator() {..比较Person的大小..},

MyCompartor里面实现了怎么比较两个Person的大小. 所以,用这种方法,当我们要对一个 person进行排序的时候, 
我们除了了要传递person过去, 还需要把MyCompartor传递过去,因为怎么比较Person的大小是在MyCompartor
里面实现的, 如:

Arrays.sort(person,new MyCompartor());


实例1:

import java.util.Arrays;

public class Demo01_Comparable {

	public static void main(String[] args) {
		Person[] person = {new Person("李春",23),
				new Person("邓娜",27),new Person("胡兴",25),
				new Person("余凯",28),new Person("任卫",24),
				new Person("冯海",24)};
		Arrays.sort(person);
		for (Person p : person) {
			System.out.println(p);
		}
		
		//String 也实现了Comparable接口
	/*	String[] strs = {"cadg","basdf","dfda","efasd","adfs"};
		Arrays.sort(strs);
		System.out.println(Arrays.toString(strs));*/
	}

}
class Person implements Comparable<Person>{
	private String name;
	private int age;
	
	public Person() {
		
	}
	public Person(String name, int age) {
		this.name = name;
		this.age = age;
	}
	
	@Override
	public int compareTo(Person o) {
		if(this.getAge() > o.getAge()){
			return 1;
		}else if(this.getAge() < o.getAge()){
			return -1;
		}
		//相等
		return 0;
	}
	

	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;
	}

	@Override
	public String toString() {
		return "Person [name=" + name + ", age=" + age + "]";
	}
	
}

实例2:

import java.util.Arrays;
import java.util.Comparator;

public class Demo02_Compartor {

	public static void main(String[] args) {
		Person1[] person = {new Person1("李春",23),
				new Person1("邓娜",27),new Person1("胡兴",25),
				new Person1("余凯",28),new Person1("任卫",24),
				new Person1("冯海",24)};
		Arrays.sort(person,new MyCompartor());
		for (Person1 p : person) {
			System.out.println(p);
		}
		
	}

}
class Person1{
	private String name;
	private int age;
	
	public Person1() {
		
	}
	public Person1(String name, int age) {
		this.name = name;
		this.age = 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;
	}

	@Override
	public String toString() {
		return "Person [name=" + name + ", age=" + age + "]";
	}
	
}

class MyCompartor implements Comparator<Person1>{

	@Override
	public int compare(Person1 o1, Person1 o2) {
		if(o1.getAge() > o2.getAge()){
			return 1;
		}else if(o1.getAge() < o2.getAge()){
			return -1;
		}
		//相等
		return 0;
	}
	
}



  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Java中,我们可以使用Comparator接口来按照对象多个属性进行排序。 首先,我们需要定义一个实现了Comparator接口的自定义比较器。在该中,我们可以重写compare方法,该方法用于比较两个对象多个属性。 比如,假设我们有一个Person,其中包含了name、age和salary三个属性。现在我们想要按照name属性进行排序,如果name相同的话,则按照age属性进行排序,最后再按照salary属性排序。 首先,我们定义一个PersonComparator来实现Comparator接口: ``` public class PersonComparator implements Comparator<Person> { @Override public int compare(Person p1, Person p2) { int result = p1.getName().compareTo(p2.getName()); if (result == 0) { result = p1.getAge() - p2.getAge(); if (result == 0) { result = p1.getSalary() - p2.getSalary(); } } return result; } } ``` 接下来,我们可以使用该比较器来对Person对象进行排序。比如,我们创建了一个Person列表,其中包含了多个Person对象,然后调用Collections的sort方法进行排序: ``` List<Person> personList = new ArrayList<>(); // 添加Person对象到列表中 Collections.sort(personList, new PersonComparator()); ``` 这样,就可以按照name、age和salary属性的顺序对Person对象进行排序了。 需要注意的是,在compare方法中,我们可以根据需要自定义比较的逻辑,比如可以使用compareTo方法来比较字符串属性,或者使用减法来比较数值属性。最后,将比较的结果返回即可。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值