java為我們提供了一個集合的工具類,方便我們對集合進行操作,裡面的方法都是靜態方法。
Collections.sort()方法,參數:List<T>集合對象,這個對象帶著泛型,是為了保證集合中的元素具備可比較性,因此這個返回值的泛型就會特殊點, <T extends Comparable <? super T>>
默認排序字符串,是按照字母的排列順序
如果是中文,默認是按照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>{ @Override public 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); } }
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; }