写在前面:
我也是一名java语言的爱好者,仅以此文作为学习的记录,对于文中出现的代码规范,代码格式,算法效率等问题,希望各路大神不吝赐教,在下感激不尽。同是学习的同学也同样希望互相交流,取长补短。
——zsferrier@126.com
一.概述
实现了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);
}
}
