背景
异常信息 代码
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什么情况下会触发?
原创文章,作者:ItWorker,如若转载,请注明出处:https://blog.ytso.com/tech/java/291509.html