2000字范文,分享全网优秀范文,学习好帮手!
2000字范文 > Java 实现List排序的默认方法和自定义方法

Java 实现List排序的默认方法和自定义方法

时间:2022-10-22 11:06:20

相关推荐

Java 实现List排序的默认方法和自定义方法

Java|java教程

Java,List,默认

Java-java教程1.java提供的默认list排序方法

微信营销系统源码带后台管理系统,vscode 关联文件,ubuntu南非,tomcat7.0.77,sqlite 查询行数据,ecshop颜色尺码插件,前端需要js什么框架吗,爬虫暖风机灯头,php页面源码,seo博客福州推广,简单的网站下载,phpcms 网页标题,通达oa门户模板lzw

主要代码:

Android 源码 锁屏源码,vscode 调用gdb6,ubuntu唤醒键,全网扫描tomcat版本,云采爬虫,终端执行php,seo基础入门免费教程收录,yourphp 企业网站管理系统,dede企业h5模板lzw

List list = new ArrayList();list.add("刘媛媛");list.add("王硕");list.add("李明");list.add("刘迪");list.add("刘布");//升序Collections.sort(list,Collator.getInstance(java.util.Locale.CHINA));//注意:是根据的汉字的拼音的字母排序的,而不是根据汉字一般的排序方法for(int i=0;i<list.size();i++){ System.out.print(list.get(i));}System.out.println("");//降序Collections.reverse(list);//不指定排序规则时,也是按照字母的来排序的for(int i=0;i<list.size();i++){ System.out.print(list.get(i));}

发卡提取源码,ubuntu中如何输入,爬虫馆石家庄,php图片比对,运城seo推广lzw

输出结果:

李明刘布刘迪刘媛媛王硕

王硕刘媛媛刘迪刘布李明

2.自定义的排序规则:

第一种是model类实现Comparable接口,重写重写int compareTo(Object o)方法

model类:

public class StudentDTO implements Comparable{ private String name; private int age;public String getName(){ return name;}public void setName(String name){ this.name = name;}public ObjType getType(){ return type;}public void setAge(int age){ this.age= age;}@Overridepublic int compareTo(Object o){ StudentDTO sdto = (StudentDTO)o; int otherAge = sdto.getAge(); // note: enum-types comparation depend on types list order of enum method // so, if compared property is enum-type ,then its comparationfollow ObjEnum.objType order return pareTo(otherAge);}} 主方法: public static void main(String[] args){ List studentList = new ArrayList(); StudentDTO s1 = new StudentDTO (); s.setName("yuanyuan"); s.setAge(22); studentList.add(s1);StudentDTO s1 = new StudentDTO ();s.setName("lily");s.setAge(23);studentList.add(s2);Collections.sort(studentList); //按照age升序 22,23,Collections.reverse(studentList); //按照age降序 23,22 }

第二种是比较器类实现Comparator接口,重写int compare(Object o1, Object o2)方法;

model类:

public class StudentDTO implements Comparable{ private String name; private int age; public String getName() { return name; } public void setName(String name) { this.name = name; } public ObjType getType() { return type; } public void setAge(int age) { this.age= age; }} 比较器类:class MyCompartor implements Comparator{ @Override public int compare(Object o1, Object o2) { StudentDTO sdto1= (StudentDTO )o1; StudentDTO sdto2= (StudentDTO )o2; return pareTo(stdo2.getAge()) }} 主方法:public static void main(String[] args){ List studentList = new ArrayList(); StudentDTO s1 = new StudentDTO (); s.setName("yuanyuan"); s.setAge(22); studentList.add(s1); StudentDTO s1 = new StudentDTO (); s.setName("lily"); s.setAge(23); studentList.add(s2); MyComparetor mc = new MyComparetor(); Collections.sort(studentList,mc); //按照age升序 22,23, Collections.reverse(studentList,mc); //按照age降序 23,22 }

附注:

1.对于数组的排序方法如下:

String[] names = {"王林", "杨宝", "李镇", "刘迪", "刘波"}; Arrays.sort(names, com.ibm.icu.text.Collator.getInstance(com.ibm.icu.util.ULocale.SIMPLIFIED_CHINESE));//升序; System.out.println(Arrays.toString(names));

2.对于汉字的排序:可以尝试使用ICU4J会得到更好的结果,特别是姓为某些生僻字的时候,

用com.ibm.icu.text.Collator替换java.text.Collator,用com.ibm.icu.util.ULocale替换java.util.Locale

3.对于枚举类型的pareTo(enum2)是按照枚举类型值在定义时的先后顺序比较的,越后面的越大,

而不是按照值的字母先后顺序比较的。

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。