对象比较器

1.比较器的作用

对两个或多个数据想进行比较,以确定它们是否相等,或确定它们之间的大小关系及排列顺序称为比较。

前面我们学习过Arrays.sort方法可实现对象的排序操作:

public static void sort(Object[] a)


2.Comparable接口

此接口强行对实现它的每个类的对象进行整体排序。这种排序被称为类的自然排序,类的compareTo方法被称为它的自然比较方法。

public interface Comparable<T>{

int compareTo(T o);//o是要比较的对象

//比较次对象与指定对象的顺序

}

分别返回-1、0或1中的一个值

根据次对象时小于、等于还是大于指定对象。


3.Comparator接口

Comparable接口是要求自己一定类去实现,按照OO原则:对修改关闭,对扩展开放。

那么如果这个类已经定义好了,不想在去修改它,那如何实现比较呢?

Arrays.sort有一个这样的重载方法:

public static<T>void sort(T[] a,Comparator<?super T>c)

Comparator接口:强行对某个对象collection进行整体排序的比较。

int compare(T o1,T o2) //比较用来排序的两个参数。

根据第一个参数小于、等于或大于第二个参数分别返回负整数、零或正整数。


package com.vince.sort;

/**
 * 人类
 * 如果自定义类的对象要实现排序(比较),那么就要实现Comparable接口,并实现接口的
 * compareTo方法
 * @author lamp
 *
 */

public 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;
	}
	
	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 + "]";
	}
	//比较器的比较方法
	//如果当前对象小于参数对象,返回-1
	//如果当前对象等于参数对象,返回0
	//如果当前对象大于参数对象,返回1
	@Override
	public int compareTo(Person o) {
		//实现:定义对象之间的比较规则
		if(o==null){
			throw new NullPointerException();
		}
		if(this.age<o.age){
			return -1;
		}else if(this.age>o.age){
			return 1;
		}
		
		return 0;
	}

}
	

package com.vince.sort;

import java.util.Arrays;

//对象的排序
public class PersonSortDemo {
	public static void main(String[] args) {
		String[] names = {"利亚","泉彩","岛爱","藤兰","结衣","井空"};
		
		Person[] persons = { 
				new Person("利亚", 27), new Person("泉彩", 29),
				new Person("岛爱", 41), new Person("藤兰", 33),
				new Person("结衣", 25), new Person("井空", 30) };
		
		Person2[] persons2 = { 
				new Person2("利亚", 27), new Person2("泉彩", 29),
				new Person2("岛爱", 41), new Person2("藤兰", 33),
				new Person2("结衣", 25), new Person2("井空", 30) };

		
		
		Arrays.sort(names);
		System.out.println(Arrays.toString(names));
		
		//自定义类对象数组排序
		Arrays.sort(persons);
		System.out.println(Arrays.toString(persons));
		
		//使用自定义的比较器
		Arrays.sort(persons2, new Person2Comparator());
		System.out.println(Arrays.toString(persons2));
		
		
		
		
		
		
		
		
	}
}


package com.vince.sort;

/**
 * 人类
 * @author lamp
 *
 */

public class Person2{
	private String name;
	private int age;
	
	
	public Person2() {
	}
	public Person2(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 + "]";
	}
}
	

package com.vince.sort;

import java.util.Comparator;

/**
 * 自定义的类比较器
 * @author lamp
 *
 */
public class Person2Comparator implements Comparator<Person2>{

	@Override
	public int compare(Person2 o1, Person2 o2) {
		if(o1==null || o2==null){
			throw new NullPointerException();
		}
		if(o1.getAge()<o2.getAge()){
			return -1;
		}else if(o1.getAge()>o2.getAge()){
			return 1;
		}
		return 0;
	}

}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
public class Comparators { public static java.util.Comparator getComparator() { return new java.util.Comparator() { public int compare(Object o1, Object o2) { if (o1 instanceof String) { return compare( (String) o1, (String) o2); } else if (o1 instanceof Integer) { return compare( (Integer) o1, (Integer) o2); } else if (o1 instanceof Person) { return compare( (Person) o1, (Person) o2); } else { System.err.println("未找到合适的比较器"); return 1; } } public int compare(String o1, String o2) { String s1 = (String) o1; String s2 = (String) o2; int len1 = s1.length(); int len2 = s2.length(); int n = Math.min(len1, len2); char v1[] = s1.toCharArray(); char v2[] = s2.toCharArray(); int pos = 0; while (n-- != 0) { char c1 = v1[pos]; char c2 = v2[pos]; if (c1 != c2) { return c1 - c2; } pos++; } return len1 - len2; } public int compare(Integer o1, Integer o2) { int val1 = o1.intValue(); int val2 = o2.intValue(); return (val1 < val2 ? -1 : (val1 == val2 ? 0 : 1)); } public int compare(Boolean o1, Boolean o2) { return (o1.equals(o2)? 0 : (o1.booleanValue()==true?1:-1)); } public int compare(Person o1, Person o2) { String firstname1 = o1.getFirstName(); String firstname2 = o2.getFirstName(); String lastname1 = o1.getLastName(); String lastname2 = o2.getLastName(); Boolean sex1 = o1.getSex(); Boolean sex2 = o2.getSex(); Integer age1 = o1.getAge(); Integer age2 = o2.getAge(); return (compare(firstname1, firstname2) == 0 ? (compare(lastname1, lastname2) == 0 ? (compare(sex1, sex2) == 0 ? (compare(age1, age2) == 0 ? 0 : compare(age1, age2)) : compare(sex1, sex2)) : compare(lastname1, lastname2)) : compare(firstname1, firstname2)); } }; } }

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值