码迷,mamicode.com
首页 > 编程语言 > 详细

JAVA基础【集合类与排序】

时间:2014-08-20 12:42:33      阅读:212      评论:0      收藏:0      [点我收藏+]

标签:java   os   io   ar   2014   cti   时间   new   


本章主题:在本章之中,对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

JAVA基础【集合类与排序】,布布扣,bubuko.com

JAVA基础【集合类与排序】

标签:java   os   io   ar   2014   cti   时间   new   

原文地址:http://my.oschina.net/u/1791874/blog/304602

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!