A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 黑马老兵 中级黑马   /  2012-4-13 11:14  /  3327 人查看  /  5 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

怎么对ArrayList中的元素进行比较排序?跟TreeSet搞混了,大家帮我分析下。

5 个回复

倒序浏览
你只要明确了TreeSet 和AyyayList  各自独有的特点 和应用就不会搞混了。

AyyayList 排序的话  你可以定义一个比较器的类。
然后使用Collections中的sort方法进行排序

MyComparator mc = new MyComparator() ;  
Collections.sort(al, mc) ;  

评分

参与人数 1技术分 +1 收起 理由
贠(yun)靖 + 1

查看全部评分

回复 使用道具 举报
ArrayList的Sort(IComparer)方法使用指定的比较器对整个 ArrayList 中的元素进行排序。向ArrayList中添加的自定义元素,当需要排序时,需要公开比较元素方法。

回复 使用道具 举报
对ArrayList中的元素进行排序,主要考查的是对util包中的Comparator接口和Collections类的使用。

实现Comparator接口必须实现compare方法,自己可以去看API帮助文档。

创建一个Comparator实例后,用Collections.sort(List,<E>)对List中的元素进行排序。

评分

参与人数 1技术分 +1 收起 理由
贠(yun)靖 + 1

查看全部评分

回复 使用道具 举报

java.util
类 Collections
java.lang.Object
  java.util.Collections  中sort()方法
static <T> void
     sort(List<T> list, Comparator<? super T> c)
          根据指定比较器产生的顺序对指定列表进行排序。
sort(List<T> list)
          根据元素的自然顺序 对指定列表按升序进行排序。

评分

参与人数 1技术分 +1 收起 理由
贠(yun)靖 + 1

查看全部评分

回复 使用道具 举报
当然也可以实现Comparable接口,覆写compareTo方法 完成自定义的方式存放
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马