java為我們提供了一個集合的工具類,方便我們對集合進行操作,里面的方法都是靜態方法。
Collections.sort()方法,參數:List<T>集合對象,這個對象帶著泛型,是為了保證集合中的元素具備可比較性,因此這個返回值的泛型就會特殊點, <T extends Comparable <? super T>>
?
默認排序字符串,是按照字母的排列順序
java集合排序工具類、如果是中文,默認是按照ascii編碼進行排序的
自定義一個比較器,實現按照字符串的長度進行排序
定義一個類StrComparator實現Comparator類
實現方法compare(),參數:
?
import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List;public class CollectionsDemo {/*** @param args*/public static void main(String[] args) {List<String> list=new ArrayList<String>();list.add("aaa");list.add("ccc");list.add("bbb");list.add("eee");System.out.println(list);//輸出 [aaa, ccc, bbb, eee] Collections.sort(list);System.out.println(list);//輸出 [aaa, bbb, ccc, eee] List<String> list2=new ArrayList<String>();list2.add("陶");list2.add("士");list2.add("涵");System.out.println(list2);//輸出 [陶, 士, 涵] Collections.sort(list2);System.out.println(list2);//輸出 [士, 涵, 陶] List<String> list3=new ArrayList<String>();list3.add("aaa");list3.add("c");list3.add("bb");list3.add("eeee");System.out.println(list3);//輸出 [aaa, c, bb, eeee]Collections.sort(list3,new StrComparator());System.out.println(list3);//輸出 [c, bb, aaa, eeee] }} /*** 自定義比較器* @author taoshihan**/ class StrComparator implements Comparator<String>{@Overridepublic int compare(String o1, String o2) {if(o1.length()>o2.length()){return 1;}else if(o1.length()<o2.length()){return -1;}return o1.compareTo(o2);}}
javasort的用法。?
PHP版:
<?php $list=array("aaa","ccc","bbb","eee"); sort($list); print_r($list);//輸出 Array ( [0] => aaa [1] => bbb [2] => ccc [3] => eee )$list2=array("陶","士","涵"); sort($list2); print_r($list2);//輸出 Array ( [0] => 士 [1] => 涵 [2] => 陶 )$list3=array("aaa","c","bb","eeee"); usort($list3,"StrComparator"); print_r($list3);//輸出 Array ( [0] => c [1] => bb [2] => aaa [3] => eeee )//自定義的比較函數 function StrComparator($a,$b){if(strlen($a)>strlen($b)){return 1;}elseif(strlen($a)<strlen($b)){return -1;}return 0; }
?