Java >>> Collections.sort()使用方法,Comparable > @Override-compareTo()--Comparator > @Override-compare()

Collections.sort()使用方法

// 集合为整型时,不需要重写Comparable接口下的方法
// List is Integer,does't override compareTo method in the comparbal_interface
 		ArrayList<Integer> int_num = new ArrayList<>();
        int_num.add(1);
        int_num.add(3);
        int_num.add(2);
        int_num.add(9);
        int_num.add(5);
        System.out.println(int_num.toString());

        // Use Collection.sort() method
        Collections.sort(int_num);
        System.out.println(int_num.toString());
// 结果如下
// Give the result follows
[1, 3, 2, 9, 5]
[1, 2, 3, 5, 9]

// 当需要为自己的自定义类排序时,则需要重写Compareble内的compareTo方法
// 需要自定义类实现Comparable内的compareTo方法
// for yourself class sort , need override compareTo method in the Comparable
// need yourself defined class implement compareTo in the Comparable_interface

// 自己定义的类
// Yourself defined class
**// 方法1 自定义类重写的compareTo方法在在自定义类最下方 (升序)
// 使用自定义类中的age属性进行排序
// method 1 **

public class PeopleClass implements Comparable<PeopleClass>{
    String name ;
    Integer age;

    // Create Constructor
    public PeopleClass() {
    }

    public PeopleClass(String name, Integer age) {
        this.name = name;
        this.age = age;
    }

    // Create get() and set() method
    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }

    public Integer getAge() {
        return age;
    }

    public void setAge(Integer age) {
        this.age = age;
    }

    // Override equals() and hashCode()
    @Override
    public boolean equals(Object o) {
        if (this == o)
            return true;
        if (o == null || getClass() != o.getClass())
            return false;
        PeopleClass that = (PeopleClass) o;

        return Objects.equals(name, that.name) &&
                Objects.equals(age, that.age);
    }

    @Override
    public int hashCode() {
        return Objects.hash(name, age);
    }

    @Override
    public String toString() {
        return "PeopleClass{" +
                "name='" + name + '\'' +
                ", age=" + age +
                '}';
    }

	// compareTo method !!!!
    @Override
    public int compareTo(PeopleClass o) {
        System.out.println("[this.age -->" + '[' + this.name + ']' + this.age + "]----[" +
         '[' + o.name + ']' + " o.age -->" + o.age + "]");
        return this.age - o.age;
    }
}

// 运行程序
// run program

		ArrayList<PeopleClass> pe = new ArrayList<>();
        pe.add(new PeopleClass("古力娜扎", 11));
        pe.add(new PeopleClass("迪丽热巴", 18));
        pe.add(new PeopleClass("马尔扎哈0", 21));
        pe.add(new PeopleClass("马尔扎哈1", 34));
        pe.add(new PeopleClass("马尔扎哈2", 26));
        pe.add(new PeopleClass("马尔扎哈3", 91));

        // print current array list
        System.out.println(pe.toString());

        // now sort
        Collections.sort(pe);

        // print array list on the sort after
        System.out.println(pe.toString());

// 结果如下
// give the result follows

[PeopleClass{name=‘古力娜扎’, age=11}, PeopleClass{name=‘迪丽热巴’, age=18}, PeopleClass{name=‘马尔扎哈0’, age=21}, PeopleClass{name=‘马尔扎哈1’, age=34}, PeopleClass{name=‘马尔扎哈2’, age=26}, PeopleClass{name=‘马尔扎哈3’, age=91}]
// 比较过程
[this.age -->[迪丽热巴]18]----[[古力娜扎] o.age -->11]
[this.age -->[马尔扎哈0]21]----[[迪丽热巴] o.age -->18]
[this.age -->[马尔扎哈1]34]----[[马尔扎哈0] o.age -->21]
[this.age -->[马尔扎哈2]26]----[[马尔扎哈1] o.age -->34]
[this.age -->[马尔扎哈2]26]----[[马尔扎哈0] o.age -->21]
[this.age -->[马尔扎哈2]26]----[[马尔扎哈1] o.age -->34]
[this.age -->[马尔扎哈3]91]----[[马尔扎哈0] o.age -->21]
[this.age -->[马尔扎哈3]91]----[[马尔扎哈1] o.age -->34]
[PeopleClass{name=‘古力娜扎’, age=11}, PeopleClass{name=‘迪丽热巴’, age=18}, PeopleClass{name=‘马尔扎哈0’, age=21}, PeopleClass{name=‘马尔扎哈2’, age=26}, PeopleClass{name=‘马尔扎哈1’, age=34}, PeopleClass{name=‘马尔扎哈3’, age=91}]

// 方法2
// method 2

// 根据自定义类内的age属性排序 (升序)

ArrayList<PeopleClass> pe = new ArrayList<>();
pe.add(new PeopleClass("古力娜扎", 11));
pe.add(new PeopleClass("迪丽热巴", 18));
pe.add(new PeopleClass("马尔扎哈0", 21));
pe.add(new PeopleClass("马尔扎哈1", 34));
pe.add(new PeopleClass("马尔扎哈2", 26));
pe.add(new PeopleClass("马尔扎哈3", 91));
// print current array list
System.out.println(pe.toString());

Collections.sort(pe, new Comparator<PeopleClass>() {
@Override
public int compare(PeopleClass o1, PeopleClass o2) {
	// 打印过程
	System.out.println("[o1.age -->" + '[' + o1.name + ']' + o1.age + "]----[" + '['
	         + o2.name + ']' + " o2.age -->" + o2.age + "]");
	 return o1.age - o2.age;
}
System.out.println(pe.toString());

// 结果如下
[PeopleClass{name=‘古力娜扎’, age=11}, PeopleClass{name=‘迪丽热巴’, age=18}, PeopleClass{name=‘马尔扎哈0’, age=21}, PeopleClass{name=‘马尔扎哈1’, age=34}, PeopleClass{name=‘马尔扎哈2’, age=26}, PeopleClass{name=‘马尔扎哈3’, age=91}]
// 比较过程
[o1.age -->[迪丽热巴]18]----[[古力娜扎] o2.age -->11]
[o1.age -->[马尔扎哈0]21]----[[迪丽热巴] o2.age -->18]
[o1.age -->[马尔扎哈1]34]----[[马尔扎哈0] o2.age -->21]
[o1.age -->[马尔扎哈2]26]----[[马尔扎哈1] o2.age -->34]
[o1.age -->[马尔扎哈2]26]----[[马尔扎哈0] o2.age -->21]
[o1.age -->[马尔扎哈2]26]----[[马尔扎哈1] o2.age -->34]
[o1.age -->[马尔扎哈3]91]----[[马尔扎哈0] o2.age -->21]
[o1.age -->[马尔扎哈3]91]----[[马尔扎哈1] o2.age -->34]
[PeopleClass{name=‘古力娜扎’, age=11}, PeopleClass{name=‘迪丽热巴’, age=18}, PeopleClass{name=‘马尔扎哈0’, age=21}, PeopleClass{name=‘马尔扎哈2’, age=26}, PeopleClass{name=‘马尔扎哈1’, age=34}, PeopleClass{name=‘马尔扎哈3’, age=91}]

// 方法3
// method 3

// 根据自定义类内的name属性排序
// 当age属性重复时 (获取首字符,进行排序)

ArrayList<PeopleClass> pe = new ArrayList<>();
		pe.add(new PeopleClass("古力娜扎", 11));
		pe.add(new PeopleClass("迪丽热巴", 18));
		pe.add(new PeopleClass("马尔扎哈0", 21));
		pe.add(new PeopleClass("马尔扎哈1", 34));
		pe.add(new PeopleClass("马尔扎哈2", 26));
		pe.add(new PeopleClass("马尔扎哈3", 91));
		
		// print current array list
		System.out.println(pe.toString());

        Collections.sort(pe, new Comparator<PeopleClass>() {
            @Override
            public int compare(PeopleClass o1, PeopleClass o2) {
                int result = o2.age - o1.age;
                if (result == 0) {
                    System.out.println("o1.name.charAt(0) -->" + o1.name.charAt(0) + "\no2.name.charAt(0) -->" + o2.name.charAt(0));
                    result = o1.name.charAt(0) - o2.name.charAt(0);
                }
                return result;
            }
        });

// 结果如下
// give the result follows

[PeopleClass{name=‘古力娜扎’, age=11}, PeopleClass{name=‘迪丽热巴’, age=18}, PeopleClass{name=‘马尔扎哈0’, age=21}, PeopleClass{name=‘马尔扎哈1’, age=34}, PeopleClass{name=‘马尔扎哈2’, age=26}, PeopleClass{name=‘马尔扎哈3’, age=91}]
[PeopleClass{name=‘古力娜扎’, age=11}, PeopleClass{name=‘迪丽热巴’, age=18}, PeopleClass{name=‘马尔扎哈0’, age=21}, PeopleClass{name=‘马尔扎哈1’, age=34}, PeopleClass{name=‘马尔扎哈2’, age=26}, PeopleClass{name=‘马尔扎哈3’, age=91}]

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
JavaComparatorComparable都是用于对象排序的接口,它们的区别在于: 1. Comparable是在对象内部实现的接口,实现了Comparable接口的类可以通过实现compareTo()方法来指定对象之间的自然排序规则。例如,如果一个类实现了Comparable接口,那么它的对象可以直接通过Collections.sort()或Arrays.sort()方法进行排序。 2. Comparator是在对象外部实现的接口,它可以用于对不支持自然排序的类进行排序。Comparator接口中定义了一个compare()方法,用于比较两个对象的大小关系。在排序时,可以通过传入一个Comparator对象来指定排序规则。 举个例子,假设我们有一个Circle类,它有radius属性,我们可以通过实现Comparable接口来指定Circle对象之间的自然排序规则,如下所示: ```java public class Circle implements Comparable<Circle> { private double radius; public Circle(double radius) { this.radius = radius; } public double getRadius() { return radius; } @Override public int compareTo(Circle o) { if (this.radius < o.radius) { return -1; } else if (this.radius > o.radius) { return 1; } else { return 0; } } } ``` 在上面的例子中,我们通过实现Comparable接口来指定Circle对象之间的自然排序规则,即按照半径从小到大排序。现在我们可以直接使用Collections.sort()方法对Circle对象进行排序,如下所示: ```java List<Circle> circles = new ArrayList<>(); circles.add(new Circle(3)); circles.add(new Circle(1)); circles.add(new Circle(2)); Collections.sort(circles); System.out.println(circles); // 输出:[Circle(radius=1.0), Circle(radius=2.0), Circle(radius=3.0)] ``` 如果我们想要按照半径从大到小排序,可以通过实现Comparator接口来指定排序规则,如下所示: ```java public class CircleComparator implements Comparator<Circle> { @Override public int compare(Circle o1, Circle o2) { if (o1.getRadius() < o2.getRadius()) { return 1; } else if (o1.getRadius() > o2.getRadius()) { return -1; } else { return 0; } } } ``` 在上面的例子中,我们通过实现Comparator接口来指定Circle对象之间的排序规则,即按照半径从大到小排序。现在我们可以通过传入一个CircleComparator对象来对Circle对象进行排序,如下所示: ```java List<Circle> circles = new ArrayList<>(); circles.add(new Circle(3)); circles.add(new Circle(1)); circles.add(new Circle(2)); Collections.sort(circles, new CircleComparator()); System.out.println(circles); // 输出:[Circle(radius=3.0), Circle(radius=2.0), Circle(radius=1.0)] ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值