用TreeSet存儲對象(使用比較器)

#日常練習

用TreeSet存儲對象2(使用比較器)

在存儲的自定義對象不具備比較性或比較方式不符合自己的要求時可以使用比較器來達到要求

相對於複寫compareTo方法,使用比較器的方式更加常用;

package Collection;

import java.util.Comparator;
import java.util.Iterator;
import java.util.TreeSet;

public class TreeSetTest02 {

	public static void main(String[] args) {
		TreeSet<String> ts = new TreeSet<String>(new StringLengthComparator());
		ts.add("dbhu");
		ts.add("ibe");
		ts.add("ie");
		ts.add("cnnjv");
		//ts.add("cnnjv");
		ts.add("n");
		ts.add("dn");
		
		for(Iterator<String> it = ts.iterator();it.hasNext();) {
			String a = (String)it.next();
			System.out.println(a);
		}
	}
}
class StringLengthComparator implements Comparator<String>{
	public int compare(String s1,String s2) {

		int num = s1.length()-s2.length();
		if(num == 0) {
			return s1.compareTo(s2);
		}
		return num;
	}
}

	
2018/1/17更新:學習了泛型將代碼完善了,功能沒變。


發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章