当集合中存储的都是对象时,我们要对其进行排序,就要借助于Comparator或Comparable,以简单的方式实现对象排序或自定义排序。
例子:一个对象类:
- public class UserPo{
- // 名字
- private String name;
- // 年龄
- private int age;
- public String getName(){
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public int getAge() {
- return age;
- }
- public void setAge(int age) {
- this.age = age;
- }
- }
1:使用Comparator接口实现排序:实现其compare方法,根据第一个参数小于、等于或大于第二个参数分别返回负整数、零或正整数来判断大小。
强行对某个对象 collection 进行整体排序 的比较函数。可以将 Comparator 传递给 sort 方法(如 Collections.sort 或 Arrays.sort),从而允许在排序顺序上实现精确控制。还可以使用 Comparator 来控制某些数据结构(如有序 set或有序映射)的顺序,或者为那些没有自然顺序的对象 collection 提供排序。
- import java.util.Comparator;
- public class MyCompare implements Comparator<Object>{
- public int compare(Object o0, Object o1) {
- UserPo user0 = (UserPo) o0;
- UserPo user1 = (UserPo) o1;
- if (user0.getAge() > user1.getAge()) {
- return 1; // 第一个大于第二个
- } else if (user0.getAge() < user1.getAge()) {
- return -1;// 第一个小于第二个
- } else {
- return 0; // 等于
- }
- }
- }
测试代码:
- import java.util.ArrayList;
- import java.util.Collections;
- public class Test {
- public static void main(String args[]){
- String sql="select name,age from users";
- // 从数据库中得到数据并组装对象集合
- ArrayList<UserPo> array =BaseDao.getyAll(sql);
- MyCompare comp = new MyCompare();
- // 执行排序方法
- Collections.sort(array,comp);
- for(UserPo p:array) {
- System.out.println(p.getName()+":"+p.getAge());
- }
- }
- }
getAll()方法:
- public static ArrayList<UserPo> getyAll(String sql) {
- ArrayList<UserPo> list = new ArrayList<UserPo>();
- ResultSet rs = null;
- PreparedStatement ps = null;
- try {
- Connection con = JdbcUtils.getMsConnection();
- ps = con.prepareStatement(sql);
- rs = ps.executeQuery();
- while (rs.next()) {
- UserPo p = new UserPo();
- p.setName(rs.getString("name"));
- p.setAge(rs.getInt("age"));
- list.add(p);
- }
- } catch (Exception e) {
- e.printStackTrace();
- }
- return list;
- }
2:使用Comparable接口完成排序:实现此接口的对象列表(和数组)可以通过 Collections.sort(和 Arrays.sort)进行自动排序。实现此接口的对象可以用作有序映射中的键或有序集合中的元素,无需指定比较器。
对UserPo类进行改装
- import java.util.ArrayList;
- import java.util.Collections;
- public class UserPo implements Comparable {
- private String name;
- private int age;
- public String getName() {
- return name;
- }
- public void setName(String name) {
- this.name = name;
- }
- public int getAge() {
- return age;
- }
- public void setAge(int age) {
- this.age = age;
- }
- /**
- * compareTo
- */
- public int compareTo(Object o) {
- return this.age-((UserPo)o).getAge();
- }
- // 测试
- public static void main(String args[]){
- String sql="select name,age from users";
- ArrayList<UserPo> array =BaseDao.getyAll(sql);
- // 执行排序方法
- Collections.sort(array);
- for(UserPo p:array) {
- System.out.println(p.getName()+":"+p.getAge());
- }
- }
- }
这两个接口的比较:
1:Comparable是在集合内部定义的方法实现的排序,Comparator是在集合外部实现的排序
2:一个类实现了Camparable接口则表明这个类的对象之间是可以相互比较的,这个类对象组成的集合就可以直接使用sort方法排序。一般我们写的bean都要实现这一接口,这也是标准javabean的规范。
3:Comparator可以看成一种算法的实现,将算法和数据分离,Comparator也可以在下面两种环境下使用:
1) 类的设计师没有考虑到比较问题而没有实现Comparable,可以通过Comparator来实现排序而不必改变对象本身
2) 可以使用多种排序标准,比如升序、降序等。
相关推荐
在编程领域,集合对象排序是一项基础且重要的任务,它涉及到数据结构和算法的知识。当我们处理包含多个元素的数据集,如数组、列表或集合时,排序能够帮助我们快速查找、分析和展示信息。本文将深入探讨如何对对象...
对集合中的对象进行排序,例如:List中存放了User对象,则可根据User对象的某一个属性进行顺序or倒序的排序
导入jar 包 调用 String[] arr1 = new String[1]; ... 参数1 排序的集合 参数2 排序的字段(与定义字段一致) 可多个 参数3 排序方式(asc desc) 暂时只支持String 和int的排序 可能有些BUG 敬请谅解
在Java编程中,经常需要对`List`集合中的对象按照特定属性进行排序。传统的方法是在每个实体类中重写`Comparable`接口或提供比较器(`Comparator`),这不仅增加了代码量,而且降低了代码的可维护性和复用性。为了...
### Java集合排序及Java集合类详解 #### 一、集合框架概述 集合框架是Java编程语言的核心组件之一,用于组织和操作数据集。Java集合框架提供了多种数据结构,包括列表(List)、集(Set)和映射(Map),这些数据结构...
对象集合的使用使得我们可以方便地处理大量对象,同时也可以通过集合类提供的方法实现对对象的排序、筛选等操作。对象集合的概念在实际开发中广泛应用于数据存储、图形用户界面组件管理、网络通信等多种场景。 **...
JAVA像SQL一样对List对象集合进行排序 在本文中,我们将详细介绍如何使用JAVA像SQL一样对List对象集合进行排序。我们将通过五个部分,分别介绍字符串List排序、整数类型List排序、对象字段对对象List排序、使用...
### Java中进行集合排序 在Java编程中,对集合(如`List`)中的对象进行排序是一项常见的操作。本文将详细介绍如何根据对象的特定属性来实现升序或降序排序。 #### 标题:Java中进行集合排序 该标题表明文章的...
在Java集合排序方面,我们主要关注List和Map。对于List,可以使用Collections.sort()方法进行排序,这个方法默认使用元素的自然顺序,如果元素是自定义对象,需要实现Comparable接口或者提供Comparator。对于Map,...
在Java编程语言中,ArrayList是...总的来说,对ArrayList中的对象进行排序涉及到Java集合框架的核心概念,包括List接口、Collections工具类以及Comparator接口。理解这些知识点对于编写高效、灵活的Java代码至关重要。
在Java集合框架中,`Collections.sort()`方法可以对List类型的集合进行排序。如果列表元素实现了`Comparable`接口,它会自动排序。如果列表元素是自定义对象,那么`compareTo()`方法将决定排序规则。 3. **...
本文将深入探讨Java中集合排序的相关知识点,包括基本概念、排序方法以及常用类的实现。 1. **集合接口与实现** Java集合框架主要包括`List`, `Set`, 和 `Map`三大接口。其中,`List`接口要求元素有序,允许重复;...
在开发中,我们可能会遇到,我们会根据不同情况对一个List集合进行排序操作,为了方便List集合根据对象中的某一个属性进行排序,开发了此工具类:
在Java编程语言中,对象排序是一项关键操作,特别是在处理集合数据结构时。本文将深入探讨如何对ArrayList、HashSet、TreeSet以及数组中的对象进行排序。理解这些排序机制对于编写高效且可维护的代码至关重要。 ...
在Java编程语言中,对象集合是程序设计中不可或缺的一部分,它们允许我们存储和管理各种类型的对象。本篇文章将深入探讨Java中的几个主要对象集合:Hashtable、Vector、LinkedList以及数组和集合的基本概念。 首先...
在Java编程中,对List集合中的对象进行多属性排序是一项常见的任务。这通常涉及到自定义比较逻辑,以满足复杂的数据排序需求。在这个“java版本List中对象多属性排序.rar”压缩包中,我们可能找到了一个关于如何在...
这样,`List`对象集合的排序就变得更加灵活和多样化,可以根据业务需求定制排序规则。`Comparator`接口是Java集合框架中的一个重要工具,对于理解和掌握数据结构的排序功能至关重要。通过深入理解并熟练运用`...