Java 中 List 元素排序

转载请注明来源: http://blog.csdn.net/kjunchen/article/details/51559020

Java 中 List 元素排序

对 List 中的元素进行排序可以使用 java.util.Collections 类中的sort()方法。既可以给方法传递一个 List 对象,也可以传递一个 List 和一个 Comparator 。如果列表中的元素全都是相同类型的类,并且这个类实现了 Comparable 接口,可以简单的调用 Collections.sort() 。如果这个类没有实现 Comparator ,你也可以传递一个 Comparator 到方法 sort() 中,进行排序。如果你不想使用缺省的分类顺序进行排序,你同样可以传递一个 Comparator 到方法 sort() 中来进行排序。

方式一: List 中对象实现 Comparable 接口

1、 创建对象并实现 Comparable 接口

public class Cat implements Comparable<Cat> {
    private String name;
    private Integer order;

    public Cat(String name, Integer order) {
        super();
        this.name = name;
        this.order = 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 int compareTo(Cat o) {
        return this.getOrder().compareTo(o.getOrder());
    }

    @Override
    public String toString() {
        return "Cat [name=" + name + ", order=" + order + "]";
    }
}

2、 调用 Collections.sort(List) 方法进行排序

public static void main(String[] args) {
    List<Cat> catList = new ArrayList<>();
    Cat cat1 = new Cat("name1", 1);
    Cat cat2 = new Cat("name2", 2);
    Cat cat3 = new Cat("name3", 3);
    catList.add(cat3);
    catList.add(cat1);
    catList.add(cat2);
    System.out.println("未排序: " + catList.toString());
    //调用 Collections.sort() 方法进行排序
    Collections.sort(catList);
    System.out.println("排序后: " + catList.toString());
}

执行结果为:

未排序: [Cat [name=name3, order=3], Cat [name=name1, order=1], Cat [name=name2, order=2]]
排序后: [Cat [name=name1, order=1], Cat [name=name2, order=2], Cat [name=name3, order=3]]

方式二: 重载 Collections.sort() 方法

1、 创建对象

public class Dog {
    private String name;
    private Integer order;

    public Dog(String name, Integer order) {
        super();
        this.name = name;
        this.order = 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 "Dog [name=" + name + ", order=" + order + "]";
    }

}

2、 调用 Collections.sort(List, Comparator) 方法进行排序

public static void main(String[] args) {
        List<Dog> dogList = new ArrayList<>();
        Dog dog1 = new Dog("name1", 1);
        Dog dog2 = new Dog("name2", 2);
        Dog dog3 = new Dog("name3", 3);
        dogList.add(dog3);
        dogList.add(dog1);
        dogList.add(dog2);
        System.out.println("未排序: " + dogList.toString());
        //调用 Collections.sort() 方法进行排序,传入List 和 Comparator
        Collections.sort(dogList, new Comparator<Dog>() {
            @Override
            public int compare(Dog o1, Dog o2) {
                return o1.getOrder().compareTo(o2.getOrder());
            }
        });
        System.out.println("排序后: " + dogList.toString());
    }

执行结果为:

未排序: [Dog [name=name3, order=3], Dog [name=name1, order=1], Dog [name=name2, order=2]]
排序后: [Dog [name=name1, order=1], Dog [name=name2, order=2], Dog [name=name3, order=3]]

欢迎加QQ群交流: 365532949
Homepage: http://junkchen.com

阅读终点,创作起航,您可以撰写心得或摘录文章要点写篇博文。去创作
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Java,可以使用Collections类的sort()方法来对List进行排序。这个方法使用了默认的排序顺序,也就是说,如果List元素是基本数据类型或实现了Comparable接口的对象,那么它们将按照升序排列。下面是一个示例: ```java import java.util.ArrayList; import java.util.Collections; import java.util.List; public class ListSortingExample { public static void main(String[] args) { List<Integer> numbers = new ArrayList<>(); numbers.add(5); numbers.add(2); numbers.add(10); numbers.add(1); System.out.println("Before sorting: " + numbers); Collections.sort(numbers); System.out.println("After sorting: " + numbers); } } ``` 输出结果为: ``` Before sorting: [5, 2, 10, 1] After sorting: [1, 2, 5, 10] ``` 如果你想按照其他特定的排序顺序进行排序,可以使用Comparator接口来实现自定义的比较器。你可以在sort()方法传入一个Comparator对象来指定排序规则。以下是一个使用Comparator进行自定义排序的示例: ```java import java.util.ArrayList; import java.util.Collections; import java.util.Comparator; import java.util.List; public class ListSortingExample { public static void main(String[] args) { List<String> names = new ArrayList<>(); names.add("John"); names.add("Alice"); names.add("Bob"); names.add("Charlie"); System.out.println("Before sorting: " + names); Collections.sort(names, new Comparator<String>() { @Override public int compare(String name1, String name2) { return name1.compareTo(name2); } }); System.out.println("After sorting: " + names); } } ``` 输出结果为: ``` Before sorting: [John, Alice, Bob, Charlie] After sorting: [Alice, Bob, Charlie, John] ``` 在这个示例,我们使用了匿名内部类来创建一个Comparator对象,并在compare()方法实现了自定义的排序规则。这里我们使用了String的compareTo()方法来进行比较,以实现按字母顺序排序

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Junk Chen

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值