Java中的集合未排序并给出错误

时间:2019-06-25 05:59:01

标签: java

我正在尝试对列表进行排序,但是比较器有问题。我的列表是A,我正在尝试按某个int进行排序,但出现错误...而且我无法使用lamda表达式或继承...任何帮助...

代码:

List<?> sortbenefitList = new ArrayList();
List<SelectItem> sortedBenefitList = new ArrayList<SelectItem>();
            Map<String,Integer> map=new HashMap<String, Integer>();
            for(IBen benefit : benefitList){
                Collections.sort(benefitList, benefit.getStartSegmentNumber());

                SelectItem item = new SelectItem();
                item.setValue(benefit.getBenefitId().toString());
                item.setLabel(benefit.getStartSegmentNumber().toString());
                sortedBenefitList.add(item);
            }
            if(sortedBenefitList != null && !sortedBenefitList.isEmpty()){
                Collections.sort(benefitList, benefit.getStartSegmentNumber().toString()) {

                    public int compare(SelectItem a1, SelectItem a2) {
                        String a1Lebel = a1.getLabel();
                        String a2Lebel = a2.getLabel();
                        Integer a1Int = Integer.parseInt(a1Lebel);
                        Integer a2Int = Integer.parseInt(a2Lebel);
                        a1Int.compareTo(a2Int)
                        map.put();
                        return a1Int.compareTo(a2Int);
                    }
                });
            }

以上是我的代码。

1 个答案:

答案 0 :(得分:0)

您的代码应如下所示: 您不需要2个列表。只有一个。 sort方法将对传递的列表进行排序

twoSum(new int[] {4,5,7,5},10)

您也可以使用比较int:

List<SelectItem> benefitList = new ArrayList<SelectItem>();
//add items
Comparator<SelectItem> comparator = (o1, o2) -> Integer.compare(Integer.parseInt(o1.getLabel()), Integer.parseInt(o2.getLabel()));
Collections.sort(benefitList, comparator);

或如果不能使用lambda则使用匿名类

Comparator<SelectItem> comparator = Comparator.comparingInt(o -> Integer.parseInt(o.getLabel()));