按字母顺序排列对象的ArrayList

时间:2013-10-19 20:49:58

标签: java sorting arraylist

我必须创建一个方法,根据电子邮件按字母顺序对对象的 ArrayList 进行排序,然后打印已排序的数组。我在排序它时遇到麻烦的部分。我已经研究过并尝试使用Collections.sort(vehiclearray);,但这对我不起作用。我是因为我需要一种称为比较器的东西,但无法弄清楚它是如何工作的。我是否必须使用那些或类似于冒泡排序或插入排序工作的东西?

这是我到目前为止的代码:

public static void printallsort(ArrayList<vehicle> vehiclearray){

   ArrayList<vehicle> vehiclearraysort = new ArrayList<vehicle>();
   vehiclearraysort.addAll(vehiclearray);

 //Sort
   for(int i = 0; i < vehiclearraysort.size(); i++) 
   if ( vehiclearray.get(i).getEmail() > vehiclearray.get(i+1).getEmail())

//Printing 
   for(i = 0; i < vehiclearraysort.size(); i++)           
   System.out.println( vehiclearraysort.get(i).toString() + "\n");

}

5 个答案:

答案 0 :(得分:79)

排序部分可以通过实现自定义Comparator<Vehicle>来完成。

Collections.sort(vehiclearray, new Comparator<Vehicle>() {
    public int compare(Vehicle v1, Vehicle v2) {
        return v1.getEmail().compareTo(v2.getEmail());
    }
});

此匿名类将用于按字母顺序在相应的电子邮件的基础上对Vehicle中的ArrayList个对象进行排序。

升级到Java8还可以通过方法引用以更简洁的方式实现它:

Collections.sort(vehiclearray, Comparator.comparing(Vehicle::getEmail));

答案 1 :(得分:12)

虽然这个问题已经有了一个公认的答案,但我想分享一些Java 8解决方案

// if you only want to sort the list of Vehicles on their email address
Collections.sort(list, (p1, p2) -> p1.getEmail().compareTo(p2.getEmail()));

// sort the Vehicles in a Stream
list.stream().sorted((p1, p2) -> p1.getEmail().compareTo(p2.getEmail()));

// sort and print with a Stream in one go
list.stream().sorted((p1, p2) -> p1.getEmail().compareTo(p2.getEmail())).forEach(p -> System.out.printf("%s%n", p));

// sort with an Comparator (thanks @Philipp)
// for the list
Collections.sort(list, Comparator.comparing(Vehicle::getEmail));
// for the Stream
list.stream().sorted(Comparator.comparing(Vehicle::getEmail)).forEach(p -> System.out.printf("%s%n", p));

答案 2 :(得分:0)

在此链接中,您可以找到有助于按降序和升序对对象的arraylist进行排序的代码。

http://beginnersbook.com/2013/12/java-arraylist-of-object-sort-example-comparable-and-comparator/

答案 3 :(得分:0)

包srikanthdukuntla;

import java.util.ArrayList; import java.util.List;

public class AlphabetsOrder {

public static void main(String[] args) {

    String temp;
    List<String> str= new ArrayList<String>();

    str.add("Apple");
    str.add("zebra");
    str.add("Umberalla");
    str.add("banana");
    str.add("oxo");
    str.add("dakuntla");
    str.add("srikanthdukuntla");
    str.add("Dukuntla");

    for(int i=0;i<str.size();i++){

        for(int j=i+1;j<str.size();j++){

     if(str.get(i).compareTo(str.get(j))<0){

            temp=str.get(i);
            str.set(i, str.get(j));
            str.set(j,temp );   

     }
        }
    }

  System.out.println("List of words in alphabetical order   "+str);

}

}

答案 4 :(得分:0)

最清晰

vehiclearray.sort(Comparator.comparing(Vehicle::getEmail()));
相关问题