Java中集合排序的两种方法

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

/**
 *
 * <p>
 * ClassName CollectionsSort
 * </p>
 * <p>
 * Description 主要介绍两种集合的排序算法<br/>
 * 第一:java.util.Collections.sort(java.util.List),要求所排序元素必须实现java.lang.Comparable接口 <br/>
 * 第二:java.util.Collections.sort(java.util.List, java.util.Comparator),这个方法要求实现java.util.Comparator接口 <br/>
 * 第三:下面的例子使用的是对int型属性排序,对String属性排序可以使用以下方法<br/>
 * public int compareTo(Cat o){return this.getName().compareTo(o.getName(0);}<br/>
 * 第四:compareTo()函数的说明 <br/>
 * 如果 结果;<br/>
 * <0 a<b ;<br/>=
 * ==0 a==b;<br/>
 * >=0 a>b;
 * </p>
 *
 * @author wangxu [email protected]
 *         <p>
 *         Date 2014-9-16 下午04:52:57
 *         </p>
 * @version V1.0
 *
 */

public class CollectionsSort {
	public static void main(String[] args) {
		// method1();测试第一个方法
		method2();// 测试第二个方法
	}

	public static void method1() {
		List<Cat> list = new ArrayList<Cat>();
		Cat c = new Cat("a", 10);
		list.add(c);
		c = new Cat("b", 20);
		list.add(c);
		c = new Cat("c", 3);
		list.add(c);
		// 升序排列输出
		Collections.sort(list);
		System.out.println(list);
		// 降序排列输出
		Collections.sort(list, Collections.reverseOrder());
		System.out.println(list);
	}

	public static void method2() {
		List<Cat> list = new ArrayList<Cat>();
		Cat c = new Cat("a", 10);
		list.add(c);
		c = new Cat("b", 20);
		list.add(c);
		c = new Cat("c", 3);
		list.add(c);
		Comparator<Cat> catComparator = new Cat();
		// 升序排列输出
		Collections.sort(list, catComparator);
		System.out.println(list);
		// 降序排列输出
		catComparator = Collections.reverseOrder(catComparator);
		Collections.sort(list, catComparator);
		System.out.println(list);
	}
}

class Cat implements Comparable<Cat>, Comparator<Cat> {
	private int age;
	private String name;

	public Cat() {
	}

	public Cat(String name, int age) {
		this.age = age;
		this.name = name;
	}

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

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

	public void setAge(int age) {
		this.age = age;
	}

	public void setName(String name) {
		this.name = name;
	}

	// 实现了Comparable接口,不要重写该方法
	@Override
	public int compareTo(Cat o) {
		// TODO Auto-generated method stub
		return this.age - o.age;
	}

	@Override
	public String toString() {
		// TODO Auto-generated method stub
		return "名字:" + getName() + ",年龄:" + getAge();
	}

	// 实现了Comparator接口,需要重写该方法
	@Override
	public int compare(Cat o1, Cat o2) {
		// TODO Auto-generated method stub
		return o1.getAge() - o2.getAge();
	}

}

时间: 2024-10-01 19:50:05

Java中集合排序的两种方法的相关文章

Java List集合排序的两种方法

1.使用 Collections 工具类中的 sort() 方法 参数不同: void sort(List list) 在自定义类User里面实现Comparable<User>接口,并重写抽象方法compareTo(Student o); void sort(List list, Comparator c) 第二个参数为了省事,可以直接使用匿名内部类 public class User implements Comparable<User>{ private int score;

Java中读取Map的两种方法对比

引言: 在Java中Map的使用非常频繁,我们经常会需要对Map进行遍历和读取,下面将展示两种遍历的方法以及简要分析. 1.  遍历Map方法A Map map = new HashMap(); Iterator iter = map.entrySet().iterator(); while (iter.hasNext()) { Map.Entry entry = (Map.Entry) iter.next(); Object key = entry.getKey(); Object val =

java自定义容器排序的两种方法

首先说一下排序的返回值的含义.对于参与比较的两个Object,o1和o2,如果函数的返回值为正值,把o1排在o2后面:返回值为负值,把o1排在o2前面.如果返回值是0,按照容器之前的顺序排列.在compareTo中,this相当于o1,传入的Object相当于o2 第一种方法:对于要排序的类实现Comparable接口 package sort; import java.util.ArrayList; import java.util.Collections; import java.util.

list集合排序的两种方法

1. 第一种方式使用 Collections  工具类中的 sort() 方法 顺便介绍Collections工具类的sort()方法: 参数不同: 1 . void sort(List list),按自然排序的升序排序 2. void sort(List list, Comparator c);定制排序,由Comparator控制排序逻辑 public class Test { public static void main(String[] args) { List list1 = new

java中实现多线程的两种基本方法

java中实现多线程有两种基本方法,一种是继承Thread, 另一种是实现Runnable接口. 但是因为java中子类只能继承一个父类,如果采用继承Thread类,就不能继承其他类,很受限制. 以下是采用继承Thread类的例子: public class MyThreadTest{ public static void main(String[] args){ MyThread amythread1=new MyThread("my thread 1"); MyThread amy

数据结构:图论:拓扑排序! 两种方法!

拓扑排序:(1)由偏序变成全序的过程!直观的说,偏序指集合中仅有部分成员之间可比较!而全序指集合中全体成员之间均可比较! (2)将G中所有顶点排成一个线性序列,使得图中任意一对顶点u和v,若边(u,v)∈E(G),则u在线性序列中出现在v之前. 数据结构中进行拓扑排序的方法: 方法一: (1)在有向图中选一个没有前驱的顶点且输出之! (2)从图中删除该顶点和所有以它为尾的弧. (3)重复上述两部,直至全部顶点均已输出,或者当前图中不存在无前驱的顶点为止.后一种情况说明有向图中存在环! 代码: #

Java中Compareable和Comparator两种比较器的区别

Java中Compareable和Comparator两种比较器的区别 1.引言 在java这个处处是对象的世界里,对两个对象进行按某一属性进行比较是特别常见的需求.比如书店中的书按照价格比较,亦或者是学生按照成绩进行排名等等. 对于JDK8而言,有三种实现对象比较的方法: 1.在需要比较的对象类中覆写Object类的equals()方法: 2.需要比较的类继承Comparable接口,然后在其类内部实现compareTo()方法: 3.抛去需要被比较的类,在其外部自定义一个单独的对象比较器,继

MySQL中删除数据的两种方法

转自:http://blog.csdn.net/apache6/article/details/2778878 在MySQL中有两种方法可以删除数据,一种是DELETE语句,另一种是TRUNCATE TABLE语句. DELETE语句可以通过WHERE对要删除的记录进行选择.而使用TRUNCATE TABLE将删除表中的所有记录.因此,DELETE语句更灵活. 如果要清空表中的所有记录,可以使用下面的两种方法: DELETE FROM table1 TRUNCATE TABLE table1 其

ZZUOJ 1199 大小关系(拓扑排序,两种方法_判断入度和dfs回路判断)

1 /* 2 这道题如果按照度为0的节点来判断的时候,将度为0的节点和其相连的节点(度数并减去1) 3 从图中去掉,如果度为0的节点的个数为0个但是图中的节点没有都去掉的 时候那么说明 4 出现了回路!用这种方法必须将重边去除掉! 5 6 所以推荐用dfs方式进行判断!这种方式还是比较直观的! 7 */ 8 #include<iostream> 9 #include<cstring> 10 #include<cstdio> 11 #include<algorith