繁体   English   中英

用Java对集合进行排序

[英]Sort Collections in Java

有人可以提供使用比较器在Java中对数组进行排序的示例和输出吗? 我知道我需要使用public static void sort(List list, Comparator c); ,但是比较器如何更改排序顺序?

通常,您可以仅实现Comparable并将列表传递给sort()方法。 但是,如果您需要使用Comparator参见以下完整示例:

public static void main(String args[]) {
   List<ExampleItem> examples = new LinkedList<ExampleItem>();
   //Build List 
   Collections.sort(examples, new ExampleCompartor());//Sort with your comparator
}

//Custom Class to sort
class ExampleItem{
    private int data;
}

//Compartor
static class ExampleCompartor implements Comparator<ExampleItem>{
    @Override
    public int compare(ExampleItem ex1, ExampleItem ex2) {
        return ex1.data - ex2.data;
    }
}
public class CompSample {
    public static int countVowels(String s) {
        return s.replaceAll("[^aeiouAEIOU]", "").length();
    }

    public static class NumberOfVowelsComparator implements Comparator<String> {
        public int compare(String o1, String o2) {
            int o1vowels = countVowels(o1);
            int o2vowels = countVowels(o2);

            return o2vowels - o1vowels;
        }
    }

    public static void main(String[] args) {
        String[] words = {"one", "two", "tree", "four"};
        List<String> sortedWords = Collections.sort(Arrays.asList(words),
            new NumberOfVowelsComparator());
        System.out.println(sortedWords);
    }
}

这是一个如何使用比较器进行排序的好例子。 http://www.javadeveloper.co.in/java-example/java-comparator-example.html

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM