JDK1.7和1.8中List集合中sort方法排序問題【JAVA】
阿新 • • 發佈:2019-01-29
上次做專案的過程中遇到一個對list集合排序的問題,一直困擾著我,後來一直到最後找了半天才發現問題所在。
因為我本機上JDK版本是1.8 ,而伺服器中JDK版本是1.7,因此線上下測試的過程中跑資料都好好地,
而到了線上卻總是出現問題,後來查詢很多文章才予以解決,現在特地記錄出來,方便以後查閱,也幫助大家共勉。
// // 排序勝率
// JDK1.8可用oldCountList.sort(new Comparator<ExExpertRecommendCounts>(){
//重點是這個函式
@Override
public int compare(ExExpertRecommendCounts o1, ExExpertRecommendCounts o2) {
//忽略掉大小寫後,進行字串的比較
Double s1 = o1.getWinProbability();
Double s2 = o2.getWinProbability();
//數字在ADCII中也是按照 排序的
return s1.compareTo(s2);//JDK1.8可用
// return s2.compareTo(s1);
}
});
//
// 排序勝率
// 為了適應JDK1.7
Collections.sort(oldCountList, new Comparator<ExExpertRecommendCounts>(){
//重點是這個函式
@Override
public int compare(ExExpertRecommendCounts o1, ExExpertRecommendCounts o2) {
//忽略掉大小寫後,進行字串的比較
Double s1 = o1.getWinProbability();
Double s2 = o2.getWinProbability();
//數字在ADCII中也是按照 排序的
// return s1.compareTo(s2);JDK1.8可用
// return s2.compareTo(s1);
//為了適應JDK1.7
return s1.doubleValue() == s2.doubleValue() ? 0 : (s1.doubleValue() > s2.doubleValue() ? 1 : -1);
}
});