0

ListData[]在两个字段上对一组自定义对象 ( ) 进行排序。我希望它按主题排序,并按名称排序。我认为我在自定义对象类中做了一个很好的比较器,我可以用它Arrays.sort(ld)来使我的代码工作并排序我的数组。但显然我做错了什么......

我的自定义对象:

   public class ListData implements Comparable<ListData>{
public int venueID;
public String name;
public String photoUrl;
public String tip;
public String theme;
@Override
public int compareTo(ListData ld0) {
    return this.venueID- ld0.venueID;
}

public static Comparator<ListData> ListDataThemeAndNameComparator = new Comparator<ListData>() {
    @Override
    public int compare(ListData ld1, ListData ld2) {

        String compareTheme1 = ld1.theme.toUpperCase();
        String compareTheme2= ld2.theme.toUpperCase();
        String compareName1 = ld1.name.toUpperCase();
        String compareName2= ld2.name.toUpperCase();

        //ascending
        int comp = compareTheme1.compareTo(compareTheme2); // comp themes
        if(comp==0){ // same theme
            comp= compareName1.compareTo(compareName2); // compare names 
        }
        return comp;
        }
};


}

在我的主要活动中,我有:

 ListData ld[]= new ListData[jsonResponse.size()];
(some code filling my ListData array)
 Arrays.sort(ld, ListData.ListDataThemeAndNameComparator); // compare by theme and then by name

有谁知道我做错了什么?

我编辑了我的代码但它仍然失败,现在在compareTheme1 = ld1.theme.toUpperCase();. 但我确信我的数组不是空的,我在对其进行排序之前将其记录在一行中,并且它填充了大约 500 个项目。

4

1 回答 1

1

您的ListData对象应该实现Comparable而不是Comparator接口。

EDIT:

为了清楚起见,您可以array按排序Array.sort()。要进行自定义排序,您可以在 中指定您的比较器Array.sort(),如果您不这样做,数组将按照您可以通过实现Comparable接口定义的自然顺序进行排序。因此,您有两种选择如何自定义排序:

  • 通过使用自定义比较器并在Array.sort()
  • 通过为您的项目实现Comparable接口

我建议你去实施Comparable. 您可以通过不创建新的比较器对象来节省内存,并且Comparator如果您比较不同类型的对象而不是您的情况,这很有用。

于 2012-07-23T08:54:31.490 回答