4
import java.util.*;

public class C_2 {
    public static void main(String args[]) {
        String theStrings[] = { "x", "a", "b", "c", "d" };
        List l = Arrays.asList(theStrings);
        Collections.sort(l);                            // line a
        Collections.sort(l, new ThisIsMyThing());       // line b
        System.out.println(l);
    }
}

class ThisIsMyThing implements Comparator {
    public int compare(Object o1, Object o2) {
        String s1 = (String)o1;
        String s2 = (String)o2;

        return -1 * s1.compareTo(s2);
    }
}

我了解该课程C_2基于两种不同的技术进行排序。一个是标准Collections.sort(l); ,另一个是Collections.sort(l,Comparator<>());我无法理解这种排序方法。有人可以向我解释一下吗?

4

3 回答 3

18

Collection.sort(l)假设 的内容lComparableCollection.sort(1, Comparator)使用自定义比较器来比较 的内容l,这就是您所做的。排序的想法(包括sort()方法)意味着对象必须是可比较的——在这种情况下,使用Comparableor Comparator

请注意,许多 Java 对象已经具有可比性,String包括DateNumber。对于那些,你可以使用Collection.sort(someList);

例子

假设你有一Circle堂课

public class Circle {
    double radius;

    public Circle(double radius) {
        this.radius = radius;
    }

    public double getArea(){
        return radius * radius * Math.PI;
    }
}

如果您创建了 100 个Circle对象:

ArrayList<Circle> circleList = new ArrayList<>();

for (int i = 0; i < 100; i++) {
    // adds a circle with random radius
    circleList.add(new Circle((int)(Math.random() * 100)));
}

// try to sort the list
Collections.sort(circleList);   //compilation error: must be Comparable

您无法对它们进行排序,因为 Java 不知道如何比较它们。你必须告诉 Java:

public class Circle implements Comparable<Circle> {
    double radius;

    public Circle(double radius) {
        this.radius = radius;
    }

    // you MUST override the compareTo method from the Comparable interface
    @Override
    public int compareTo(Circle cirlce){
        if (this.getArea() > circle.getArea())
            return 1;
        else if (this.getArea() == circle.getArea())
            return 0;
        else 
            return -1;
    }

    public double getArea(){
        return radius * radius * Math.PI;
    }
}

使用compareTo()Circle 类中的方法,Java 现在知道如何比较它们并可以对它们进行排序。

现在你可以这样做:

Collections.sort(circleList);
// Yayyy I'm being sorted by the size of my areas!!!!!
于 2013-10-30T13:06:36.630 回答
1

Collections.sort 采用比较器根据您提供的比较器对列表进行排序,其他遵循自然排序顺序。也就是说,如果您想遵循任何自定义排序顺序,请使用此方法。没什么好解释的。

使用此链接进行解释。

于 2013-10-30T12:59:11.470 回答
0

使用 Collections.sort(Collection) 对集合进行排序以对您的值进行排序。此方法适用于那些实现Comparable接口的人。该接口定义了compare执行元素成对比较的方法,如果元素小于比较元素,则返回 -1,如果相等则返回 0,如果大于则返回 1。一个常见的例子是整数类。

如果要进行不同的排序,您可以根据接口定义自己的实现。这种Comparator方法是您然后按任何属性甚至属性组合对任何对象进行排序。例如,如果您有 Person 类型的对象,其属性为 income 和 dateOfBirth,您可以定义 Comparator 的不同实现并根据您的需要对对象进行排序。

于 2013-10-30T13:06:11.680 回答