[b]
[url=http://www.large-flag.com]大旗领航JAVA就业培训 www.large-flag.com[/url][/b]
对象实现了Comparable接口后,TreeSet可以对其进行排序。JAVA中还提供了另外一种手段:Comparator接口,
通过该接口可以定义一个比较器,然后可以告诉TreeSet使用该比较器进行比较。
如果一个要存入TreeSet中的对象没有实现Comparable接口,则它所存入的TreeSet需要指定一个比较器。
下面是一个示例:
员工类
package demo;
public class Employee{
private String name;
private Integer age;
public Employee(String name,int age)
{
this.name=name;
this.age=age;
}
/**
* 覆盖toString()方法
* 当使用System.out.println( Employee对象 )时,输出的是该方法的返回值
*/
public String toString()
{
return name+":"+age;
}
public Integer getAge()
{
return age;
}
}
自定义比较器
package demo;
import java.util.Comparator;
/**
* 自定义比较器,按年龄大小进行排序
*/
public class EmployeeComparator implements Comparator
{
public int compare(Object obj1,Object obj2)
{
Employee temp1=(Employee)obj1;
Employee temp2=(Employee)obj2;
if(temp1.getAge()==temp2.getAge())
{
return 0;
}
if(temp1.getAge()>temp2.getAge())
{
return 1;
}
return -1;
}
}
Comparator接口中提供了compare方法;
compare方法返回0、1、-1,分别代表当前值相等、大于、小于传入的对象的值;
将员工存入TreeSet集合
1 package demo;
2 import java.util.Collection;
3 import java.util.Date;
4 import java.util.Iterator;
5 import java.util.Random;
6 import java.util.TreeSet;
7 /**
8 * 使用TreeSet
9 */
10 public class TreeSetDemo3 {
11 //循环显示集合数据
12 public static void ShowAll(Collection col)
13 {
14 Iterator iter=col.iterator();
15 while(iter.hasNext())
16 {
17 System.out.println(iter.next()+"\t");
18 }
19 System.out.println();
20 }
21
22 public static void main(String[] args) {
23 EmployeeComparator employeeComparator = new EmployeeComparator();
24 TreeSet treeSet=new TreeSet( employeeComparator );
25 Employee e1=new Employee("张三",25);
26 Employee e2=new Employee("李四",36);
27 Employee e3=new Employee("王五",30);
28 treeSet.add(e1);
29 treeSet.add(e2);
30 treeSet.add(e3);
31 System.out.println("TreeSet中的员工:");
32 TreeSetDemo3.ShowAll(treeSet);
33 }
34 }
第23行,声明一个自定义比较器
第24行,将比较器传递给TreeSet集合
输出结果如下:
TreeSet中的员工:
张三:25
王五:30
李四:36
程序实现了与前面相同的排序效果。通过该种方式,可以灵活定义多种排序规则。
[b]
[url=http://www.large-flag.com]大旗领航JAVA就业培训 www.large-flag.com[/url][/b]
[url=http://www.large-flag.com]大旗领航JAVA就业培训 www.large-flag.com[/url][/b]
对象实现了Comparable接口后,TreeSet可以对其进行排序。JAVA中还提供了另外一种手段:Comparator接口,
通过该接口可以定义一个比较器,然后可以告诉TreeSet使用该比较器进行比较。
如果一个要存入TreeSet中的对象没有实现Comparable接口,则它所存入的TreeSet需要指定一个比较器。
下面是一个示例:
员工类
package demo;
public class Employee{
private String name;
private Integer age;
public Employee(String name,int age)
{
this.name=name;
this.age=age;
}
/**
* 覆盖toString()方法
* 当使用System.out.println( Employee对象 )时,输出的是该方法的返回值
*/
public String toString()
{
return name+":"+age;
}
public Integer getAge()
{
return age;
}
}
自定义比较器
package demo;
import java.util.Comparator;
/**
* 自定义比较器,按年龄大小进行排序
*/
public class EmployeeComparator implements Comparator
{
public int compare(Object obj1,Object obj2)
{
Employee temp1=(Employee)obj1;
Employee temp2=(Employee)obj2;
if(temp1.getAge()==temp2.getAge())
{
return 0;
}
if(temp1.getAge()>temp2.getAge())
{
return 1;
}
return -1;
}
}
Comparator接口中提供了compare方法;
compare方法返回0、1、-1,分别代表当前值相等、大于、小于传入的对象的值;
将员工存入TreeSet集合
1 package demo;
2 import java.util.Collection;
3 import java.util.Date;
4 import java.util.Iterator;
5 import java.util.Random;
6 import java.util.TreeSet;
7 /**
8 * 使用TreeSet
9 */
10 public class TreeSetDemo3 {
11 //循环显示集合数据
12 public static void ShowAll(Collection col)
13 {
14 Iterator iter=col.iterator();
15 while(iter.hasNext())
16 {
17 System.out.println(iter.next()+"\t");
18 }
19 System.out.println();
20 }
21
22 public static void main(String[] args) {
23 EmployeeComparator employeeComparator = new EmployeeComparator();
24 TreeSet treeSet=new TreeSet( employeeComparator );
25 Employee e1=new Employee("张三",25);
26 Employee e2=new Employee("李四",36);
27 Employee e3=new Employee("王五",30);
28 treeSet.add(e1);
29 treeSet.add(e2);
30 treeSet.add(e3);
31 System.out.println("TreeSet中的员工:");
32 TreeSetDemo3.ShowAll(treeSet);
33 }
34 }
第23行,声明一个自定义比较器
第24行,将比较器传递给TreeSet集合
输出结果如下:
TreeSet中的员工:
张三:25
王五:30
李四:36
程序实现了与前面相同的排序效果。通过该种方式,可以灵活定义多种排序规则。
[b]
[url=http://www.large-flag.com]大旗领航JAVA就业培训 www.large-flag.com[/url][/b]