From c697420bc6278ae2404155ed5e38a9237c9c7dd4 Mon Sep 17 00:00:00 2001 From: xuxin <840198532@qq.com> Date: Sun, 1 Feb 2026 15:16:57 +0800 Subject: [PATCH] =?UTF-8?q?=E8=BF=9B=E9=98=B6day03-Collections=E9=87=8C?= =?UTF-8?q?=E9=9D=A2=E7=9A=84sort=E6=96=B9=E6=B3=95=E4=BB=A5=E5=8F=8A?= =?UTF-8?q?=E6=AF=94=E8=BE=83=E5=99=A8Comparetor=E7=9A=84=E4=BD=BF?= =?UTF-8?q?=E7=94=A8?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../src/com/inmind/collections04/Demo14.java | 1 - .../src/com/inmind/collections04/Demo15.java | 51 +++++++++++++++++++ .../src/com/inmind/collections04/Student.java | 2 +- 3 files changed, 52 insertions(+), 2 deletions(-) create mode 100644 javaSE-day03/src/com/inmind/collections04/Demo15.java diff --git a/javaSE-day03/src/com/inmind/collections04/Demo14.java b/javaSE-day03/src/com/inmind/collections04/Demo14.java index 6d3f7b5..a6efe49 100644 --- a/javaSE-day03/src/com/inmind/collections04/Demo14.java +++ b/javaSE-day03/src/com/inmind/collections04/Demo14.java @@ -5,7 +5,6 @@ import java.util.Collections; /* - public static void sort(List list):将集合中元素按照默认规则排序。 -- public static void sort(List list,Comparator ):将集合中元素按照指定规则排序。 注意: 1.要使用以上的排序api,那么List集合的泛型的类型必须实现Comparable接口. diff --git a/javaSE-day03/src/com/inmind/collections04/Demo15.java b/javaSE-day03/src/com/inmind/collections04/Demo15.java new file mode 100644 index 0000000..d049d5c --- /dev/null +++ b/javaSE-day03/src/com/inmind/collections04/Demo15.java @@ -0,0 +1,51 @@ +package com.inmind.collections04; + +import java.util.ArrayList; +import java.util.Collections; +import java.util.Comparator; + +/* +Comparable:自然排序功能 +Comparator:比较器,给指定的集合,添加排序功能,它的优先级比自然排序要高 + +注意:当一个集合中保存的数据不具有自然排序功能或者对应拥有自然排序功能的类不满足你的需求时, +就使用直接使用比较器Comparator添加排序效果或者覆盖排序效果 + +- public static void sort(List list,Comparator ):将集合中元素按照指定规则排序。 + */ +public class Demo15 { + public static void main(String[] args) { + System.out.println("--------------对Integer默认集合排序:整数的升序----------------"); + ArrayList lists1 = new ArrayList<>(); + Collections.addAll(lists1, 1, 44, 23, 56, 32, 66, 12); + System.out.println(lists1); + //调用排序功 + Collections.sort(lists1, new Comparator() {//使用匿名内部类,创建了使用一次的比较器的实现类对象 + /* + 排序口诀: + 我(o1)-它(o2):升序 + 它-我:降序 + */ + @Override + public int compare(Integer o1, Integer o2) { + return o2 - o1; + } + }); + System.out.println(lists1); + + System.out.println("-------------------对自定义对象集合排序----------------------"); + ArrayList lists3 = new ArrayList<>(); + lists3.add(new Student("张三2", 19)); + lists3.add(new Student("张三1", 18)); + lists3.add(new Student("张三3", 20)); + System.out.println(lists3); + //使用了比较器,覆盖了原本的自然排序功能 + Collections.sort(lists3, new Comparator() { + @Override + public int compare(Student o1, Student o2) { + return o2.age - o1.age; + } + }); + System.out.println(lists3); + } +} diff --git a/javaSE-day03/src/com/inmind/collections04/Student.java b/javaSE-day03/src/com/inmind/collections04/Student.java index 5d1662d..6f19258 100644 --- a/javaSE-day03/src/com/inmind/collections04/Student.java +++ b/javaSE-day03/src/com/inmind/collections04/Student.java @@ -53,7 +53,7 @@ public class Student implements Comparable{ if (this.age == o.age) { return this.id - o.id; } else { - return this.age = o.age; + return this.age - o.age; } } }