首页 > 代码库 > JAVA基础【集合类与排序】
JAVA基础【集合类与排序】
本章主题:在本章之中,对java集合 Collections.sort方法做一个简要的回顾。
package test; /** * @author Yshuai * @version 创建时间:2014-08-20 上午09:49:36 */ import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; public class SortTest { public static void main(String[] args) { List<String> lists = new ArrayList<String>(); List<A> list = new ArrayList<A>(); List<B> listB = new ArrayList<B>(); lists.add("5"); lists.add("2"); lists.add("9"); Collections.sort(lists); System.out .println("// lists中的对象String 本身含有compareTo方法,所以可以直接调用sort方法,按自然顺序排序,即升序排序" + lists); // 初始化listA方法 A aa = new A(); aa.setName("aa"); aa.setOrder(1); A bb = new A(); bb.setName("bb"); bb.setOrder(2); list.add(bb); list.add(aa); Collections.sort(list); System.out.println("在你的java实体类之中设定好你的CompareTo方法" + list); // 初始化ListB方法,B没有实现compareTo方法的情况之下,请您在Collections.Sort方法之中给Collections穿传递一个CompareTo方法 B ab = new B(); ab.setName("ab"); ab.setOrder("1"); B ba = new B(); ba.setName("ba"); ba.setOrder("2"); listB.add(ba); listB.add(ab); // 根据Collections.sort重载方法来实现 Collections.sort(listB, new Comparator<B>() { @Override public int compare(B b1, B b2) { return b1.getOrder().compareTo(b2.getOrder()); } }); System.out.println(listB); } } class A implements Comparable<A> { private String name; private Integer order; public String getName() { return name; } public void setName(String name) { this.name = name; } public Integer getOrder() { return order; } public void setOrder(Integer order) { this.order = order; } @Override public String toString() { return "name is " + name + " order is " + order; } @Override public int compareTo(A a) { return this.order.compareTo(a.getOrder()); } } class B { private String name; private String order; public String getName() { return name; } public void setName(String name) { this.name = name; } public String getOrder() { return order; } public void setOrder(String order) { this.order = order; } @Override public String toString() { return "name is " + name + " order is " + order; } }
写作背景: 由于在当前的业务当中涉及到storm的实时排序功能。在这里对Java基础进行简要的回顾,并作深化。
总结; 排序的过程之中您有两种简单的办法:
1 实现好compareTo方法,在此时Collection.sort方法将在运行中调用Bean对象的方法
2 如果您没有实现,需要为Sort 方法指定一个比较器。
SimpleTips
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。