跳转到帖子

游客您好,欢迎来到黑客世界论坛!您可以在这里进行注册。

赤队小组-代号1949(原CHT攻防小组)在这个瞬息万变的网络时代,我们保持初心,创造最好的社区来共同交流网络技术。您可以在论坛获取黑客攻防技巧与知识,您也可以加入我们的Telegram交流群 共同实时探讨交流。论坛禁止各种广告,请注册用户查看我们的使用与隐私策略,谢谢您的配合。小组成员可以获取论坛隐藏内容!

TheHackerWorld官方

java根据比较器comparator排序异常:Comparison method violates its general contract!

精选回复

发布于

背景

异常信息 代码

private void customSort(List<Customer> customers) {
          
   

        Collections.sort(customers, (c1, c2) -> c1.getActiveLevel() < c2.getActiveLevel() ? 1 :
                (c1.getActiveLevel().equals(c2.getActiveLevel()) ? (c1.getAuthStatus() > c2.getAuthStatus() ? 1 : -1) : -1));
}
public void test(int loopNum) {
          
   
        List<Customer> customers = new ArrayList<>();
        Customer c1 = new Customer();
        c1.setActiveLevel(1);
        c1.setAuthStatus(16);
        Customer c2 = new Customer();
        c2.setActiveLevel(3);
        c2.setAuthStatus(13);
        Customer c3 = new Customer();
        c3.setActiveLevel(2);
        c3.setAuthStatus(11);
        Customer c4 = new Customer();
        c4.setActiveLevel(2);
        c4.setAuthStatus(9);
        Customer c5 = new Customer();
        c5.setActiveLevel(2);
        c5.setAuthStatus(15);

        customers.add(c1);
        customers.add(c2);
        customers.add(c3);
        customers.add(c4);
        customers.add(c5);

        for (int i = 0; i < loopNum; i++) {
          
   
            customers.add(new Customer(c1));
            customers.add(new Customer(c2));
            customers.add(new Customer(c3));
            customers.add(new Customer(c4));
            customers.add(new Customer(c5));
        }

        customSort(customers);

        for (Customer customer : customers) {
          
   
            System.out.println(customer);
        }
        System.out.println("success!");
    }
@Data
public class Customer {
          
   

    private Integer activeLevel;

    private Integer authStatus;

    public Customer() {
          
   
    }

    public Customer(Customer customer) {
          
   
        this.userId = customer.getUserId();
        this.sex = customer.getSex();
        this.height = customer.getHeight();
        this.incomeNew = customer.getIncomeNew();
        this.eduLevel = customer.getEduLevel();
        this.faceScoreLevel = customer.getFaceScoreLevel();
        this.lastRequestTime = customer.getLastRequestTime();
        this.activeLevel = customer.getActiveLevel();
        this.registerTime = customer.getRegisterTime();
        this.authStatus = customer.getAuthStatus();
        this.grade = customer.getGrade();
        this.city = customer.getCity();
    }
}

测试

// 发生异常
public static void main(String[] args) {
          
   
        new PlayOnlineForVisitorsServiceImpl().test(100);
    }
// 不发生异常
public static void main(String[] args) {
          
   
        new PlayOnlineForVisitorsServiceImpl().test(2);
    }

修改customSort方法

需要考虑c1 == c2的情况

private void customSort(List<Customer> customers) {
          
   
   Collections.sort(customers, (c1, c2) -> c1.getActiveLevel() > c2.getActiveLevel() ? 1 :
                (c1.getActiveLevel().equals(c2.getActiveLevel()) ? (c1.getAuthStatus() > c2.getAuthStatus() ? -1 : (c1.getAuthStatus().equals(c2.getAuthStatus())) ? 0 : 1) : -1));
 }

重点

为什么会这个异常会有偶发性?跟着异常信息找到异常的地方。这个len2 == 0什么情况下会触发?

创建帐户或登录后发表意见

最近浏览 0

  • 没有会员查看此页面。