写在前面:
我也是一名java语言的爱好者,仅以此文作为学习的记录,对于文中出现的代码规范,代码格式,算法效率等问题,希望各路大神不吝赐教,在下感激不尽。同是学习的同学也同样希望互相交流,取长补短。
一.概述
实现了Comparable接口的自定义类T,即定义了T的比较方法compareTo(就像integer类的大于等于小于),换句话说脑洞足够大你可以任意定义自己需要的大小规则,结果是当你把T类的对象装入List容器后,可以直接通过collections.sort方法进行排序。
二.compareTo方法
int compareTo(T o)
比较此对象与指定对象的顺序。如果该对象小于、等于或大于指定对象,则分别返回负整数、零或正整数。
值得一提的是Integer和String已经实现CompareTo方法
三.实例
import java.util.ArrayList; import java.util.Arrays; import java.util.Collections; import java.util.List; public class Main { /** * @param args */ class Node implements Comparable<Node>{ public int value; public String NodeNum; public Node(int v,String s){ value = v; NodeNum =s; } @Override public int compareTo(Node arg0) {//实现compareTo // TODO Auto-generated method stub if(value<arg0.value){ return -1; }else if (value==arg0.value) { return 0; }else { return 1; } } @Override public String toString(){//重写本类对象的标准化输出 StringBuilder stringBuilder = new StringBuilder(); stringBuilder.append(value+" "); stringBuilder.append(NodeNum); return stringBuilder.toString(); } } public static void main(String[] args) { // TODO Auto-generated method stub Node n1 = new Main().new Node(3,"num1"); Node n2 = new Main().new Node(1,"num2"); Node n3 = new Main().new Node(6,"num3"); List<Node> nodeList= new ArrayList<Node>(Arrays.asList(n1,n2,n3)); Collections.sort(nodeList); System.out.println(nodeList); } }