Java使用优先级对3个字段对象的ArrayList进行排序,从而获得意外结果

时间:2015-02-14 20:00:44

标签: java sorting arraylist

我有一个班级订单(我减少了较小尺寸的制定者和吸气剂)。

class Order implements Comparable<Order>{
    private int number;
    private int price;
    private int quantity;
    private boolean isMarketOrder;
    private boolean isBuyOrder;

    @Override
    public int compareTo(Order o) {
        int value1 = Boolean.compare(this.isMarketOrder(), o.isMarketOrder());
        if (value1 != 0){
            return value1;
        }
        int value2 = Integer.compare(this.getPrice(),(o.getPrice()));
        if (value2 != 0) {
            return value2;
        }
        int value3 =  Integer.compare(this.getNumber(),(o.getNumber()));
        return value3;
    }
}

我有一份订单清单:

public static ArrayList<Order> buyOrders = new ArrayList<Order>();

我做

Collections.sort(buyOrders);

排序时我想要使用的规则:

  1. 订单使用isMarketOrder == true总是先来
  2. 具有相同isMarketOrder值的订单按价格排序,先高出
  3. 具有相同isMarketOrder的订单和价格按“数字”排序,先小一些。
  4. 实际发生的事情是价格较高的物品首先出现,isMarketOrder == true物品最后出现。

    为什么?

1 个答案:

答案 0 :(得分:5)

由于true大于false,因此您使用的排序isMarketOrder==false排序isMarkerOrder==true之前。如果你有:

int value1 = Boolean.compare(this.isMarketOrder(), o.isMarketOrder());
if (value1 != 0){
    return -value1;
}

你会得到相反的效果。