java为我们提供了一个集合的工具类,方便我们对集合进行操作,里面的方法都是静态方法。
Collections.sort()方法,参数:List<T>集合对象,这个对象带着泛型,是为了保证集合中的元素具备可比较性,因此这个返回值的泛型就会特殊点, <T extends Comparable <? super T>>
默认排序字符串,是按照字母的排列顺序
定义一个类StrComparator实现Comparator类
实现方法compare(),参数:
import java.util.ArrayList; java.util.Collections; java.util.Comparator; java.util.List; public class CollectionsDemo { /** * @param args */ 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); List<String> list2=(); list2.add("陶"); list2.add("士"); list2.add("涵"); System.out.println(list2);输出 [陶,士,涵] Collections.sort(list2); System.out.println(list2);输出 [士,涵,陶] List<String> list3=(); list3.add("aaa"); list3.add("c"); list3.add("bb"); list3.add("eeee"); System.out.println(list3);.sort(list3,new StrComparator()); System.out.println(list3);输出 [c,aaa,eeee] } } * 自定义比较器 * @author taoshihan * */ class StrComparator implements Comparator<String>{ @Override int compare(String o1,String o2) { if(o1.length()>o2.length()){ return 1; }else if(o1.length()<return -1; } return o1.compareto(o2); } }
PHP版:
<?PHP $list=array("aaa","ccc","bbb","eee"); sort($listprint_r($list);输出 Array ( [0] => aaa [1] => bbb [2] => ccc [3] => eee ) $list2=array("陶","士","涵"$list2$list2);输出 Array ( [0] => 士 [1] => 涵 [2] => 陶 ) $list3=usort($list3,"StrComparator"$list3);输出 Array ( [0] => c [1] => bb [2] => aaa [3] => eeee ) //自定义的比较函数 function StrComparator($a,$b){ if(strlen($a)>)){ ; }elseif($a)<; } return 0; }
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。