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; }
原创文章,作者:奋斗,如若转载,请注明出处:https://blog.ytso.com/12660.html