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;
}