【JAVA语法】 -- 方便的Comparable接口

写在前面:

    我也是一名java语言的爱好者,仅以此文作为学习的记录,对于文中出现的代码规范,代码格式,算法效率等问题,希望各路大神不吝赐教,在下感激不尽。同是学习的同学也同样希望互相交流,取长补短。                                                                                                                                            

——[email protected]

一.概述

    实现了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);	
	}
}

猜你喜欢

转载自blog.csdn.net/qq_37935670/article/details/79738582