1、问题:页面有个排序列表,有name和age,后台为一个Arraylist,怎么做排序好点?
2、User类,实现Comparable接口,重写里面的compareTo方法:
package com.baidu.test; public class User implements Comparable<User> { private String name; private int age; public User(String name, int age) { super(); this.name = name; this.age = age; } // 按名字排序,如果名字相同则按年龄排序 public int compareTo(User user) { if (this.name.compareTo(user.getName()) > 0) { return 1; } else if (this.name.compareTo(user.getName()) < 0) { return -1; } else { if (this.age > user.getAge()) { return 1; } else if (this.age < user.getAge()) { return -1; } } return 0; } 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; } }
3、测试:
package com.baidu.test; import java.util.ArrayList; import java.util.Collection; import java.util.Collections; import java.util.Iterator; import java.util.List; public class Test { public static void main(String[] args) { User user1 = new User("a", 1); User user2 = new User("a", 2); User user3 = new User("b", 6); User user4 = new User("c", 3); User user5 = new User("a1", 5); User user6 = new User("a4", 1); User user7 = new User("d", 5); List list = new ArrayList(); list.add(user1); list.add(user2); list.add(user3); list.add(user4); list.add(user5); list.add(user6); list.add(user7); Collections.sort(list); Iterator itr = list.iterator(); while(itr.hasNext()){ User user = (User) itr.next(); System.out.println(user.getName()+":"+user.getAge()); } } } --------------------------------------------------------- a:1 a:2 a1:5 a4:1 b:6 c:3 d:5 ---------------------------------------------------------
相关推荐
Comparable 接口和 Comparator 使用示例 在 Java 编程语言中,比较和排序是非常常见的操作。Comparable 接口和 Comparator 是两种常用的比较和排序方式。在本文中,我们将通过实例代码,详细介绍 Comparable 接口和...
### Comparable与Comparator的区别详解 #### 一、引言 在Java编程中,为了对自定义对象进行排序,Java提供了两种接口:`Comparable`与`Comparator`。这两种接口各有优势,适用于不同的场景。本文将深入探讨这两种...
在Java编程语言中,排序是数据处理中一个非常常见的需求,而`Comparator`和`Comparable`接口则是实现排序的关键工具。这两个接口都是用于比较对象,但它们的应用场景和使用方式有所不同。 首先,`Comparable`接口是...
Comparator接口与Comparable接口的区别 Comparator接口与Comparable接口是Java语言中两个重要的接口,它们都是用于比较和排序自定义类的对象的大小的。虽然它们两个都是用于比较的接口,但是它们有着不同的实现方式...
1.什么是Comparable接口 此接口强行对实现它的每个类的对象进行整体排序。此排序被称为该类的自然排序 ,类的 compareTo 方法被称为它的自然比较方法 。实现此接口的对象列表(和数组)可以通过 Collections.sort ...
在Java编程语言中,Comparable和Comparator接口是两个重要的概念,它们都用于对象的排序,但有着不同的使用场景和特点。本文将深入探讨这两个接口的区别,以及它们在实际开发中的应用。 首先,我们来了解一下...
Comparable的用法1---马克-to-win java视频的详细描述
Java-中的-Comparator-和-Comparable.md
在Java编程语言中,Comparable和Comparator接口是两个非常重要的组件,它们主要用来进行对象的比较和排序。了解它们之间的区别对于提升代码的可维护性和灵活性至关重要。 Comparable接口来源于java.lang包,它定义...
在Java编程语言中,`Comparable`接口和`Comparator`接口是两种重要的排序机制,它们用于对集合中的对象进行比较和排序。理解它们的区别对于任何Java开发者来说都是至关重要的。 首先,`Comparable`接口位于`java....
资源分类:Python库 所属语言:Python 资源全名:Comparable-0.0.3.tar.gz 资源来源:官方 安装方法:https://lanzao.blog.csdn.net/article/details/101784059
java通过Comparable接口实现字符串比较大小排序的简单实例
Comparable接口是Java中用于对象排序的关键接口,它允许类的对象之间进行比较,并定义它们的自然排序。这个接口只有一个方法:`compareTo(Object o)`,此方法用于比较当前对象与指定对象`o`的顺序。如果当前对象小于...
在Java编程语言中,Comparable和Comparator是两个非常重要的接口,它们都用于对象的比较和排序。下面是关于这两个接口的详细解释: **Comparable接口** Comparable接口位于`java.lang`包下,它是一个对象自比较的...
### Java中的Comparable与Comparator详解 #### 一、引言 在Java编程中,当我们需要对对象进行排序时,经常会用到两种方式:一种是通过实现`Comparable`接口,另一种则是通过实现`Comparator`接口。这两种方式各有...
这里我们将深入探讨Java 8 HashMap如何与Comparable接口结合使用,以及这背后的编程技术和设计原理。 首先,我们了解下Comparable接口。Comparable接口是Java中用于定义对象之间自然顺序的接口,它只有一个方法`...
教你学会Comparator和Comparable
在 Java 中,Comparator 和 Comparable 是两个非常重要的接口,它们用于对象的排序操作。这两个接口都是在 java.util 包中定义的,主要用于定制排序规则。 **一、Comparator 接口** Comparator 接口允许我们创建...
【Comparable和Comparator区分详解】 Comparable接口是Java中用于对象排序的关键接口,主要应用于需要自动排序的场景。当一个类实现了Comparable接口,意味着该类的对象具备内在的比较逻辑,可以直接进行比较。例如...
标题中的"PyPI 官网下载 | Comparable-0.2.tar.gz"表明这是一个在Python Package Index(PyPI)上发布的软件包,名为Comparable,版本为0.2,且已打包成tar.gz格式。PyPI是Python社区官方维护的一个仓库,用于发布和...