??在 Java 項目中,可能會遇到給出一些條件,將 List 元素按照給定條件進(jìn)行排序的情況。如下述場景。
一、排序場景
??List 保存著一組亂序排列的字符串,Map 中保存著該組字符串各自的優(yōu)先級。優(yōu)先級數(shù)字從低到高表示優(yōu)先級依次遞減。要求將 List 中的字符串,按照優(yōu)先級從高到低排序。文章來源:http://www.zghlxwxcb.cn/news/detail-543612.html
二、指定條件排序
??實現(xiàn) List 排序有多種方法,本文總結(jié)以下幾種。文章來源地址http://www.zghlxwxcb.cn/news/detail-543612.html
2.1 調(diào)用 list sort 方法,實現(xiàn)比較器接口進(jìn)行排序
package com.example.demo.help;
import java.util.*;
public class ListSortTest {
public static void main(String[] args) {
List<String> rules = new ArrayList<>();
rules.add("30003");
rules.add("20002");
rules.add("10001");
rules.add("40004");
rules.add("60006");
rules.add("50005");
Map<String, Integer> ruleUpper = new HashMap<>();
ruleUpper.put("10001", 1);
ruleUpper.put("20002", 2);
ruleUpper.put("30003", 3);
ruleUpper.put("40004", 4);
rules.sort(new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
return ruleUpper.getOrDefault(o1, Integer.MAX_VALUE) - ruleUpper.getOrDefault(o2, Integer.MAX_VALUE);
}
});
System.out.println(rules);
// [10001, 20002, 30003, 40004, 60006, 50005]
}
}
2.2 調(diào)用 list sort 方法,通過 lambda 表達(dá)式實現(xiàn)排序
package com.example.demo.help;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
public class ListSortTest {
public static void main(String[] args) {
List<String> rules = new ArrayList<>();
rules.add("30003");
rules.add("20002");
rules.add("10001");
rules.add("40004");
rules.add("60006");
rules.add("50005");
Map<String, Integer> ruleUpper = new HashMap<>();
ruleUpper.put("10001", 1);
ruleUpper.put("20002", 2);
ruleUpper.put("30003", 3);
ruleUpper.put("40004", 4);
rules.sort((o1, o2) -> (ruleUpper.getOrDefault(o1, Integer.MAX_VALUE) - ruleUpper.getOrDefault(o2, Integer.MAX_VALUE)));
System.out.println(rules);
// [10001, 20002, 30003, 40004, 60006, 50005]
}
}
2.3 通過 Collections sort 方法,實現(xiàn)比較器接口進(jìn)行排序
package com.example.demo.help;
import java.util.*;
public class ListSortTest {
public static void main(String[] args) {
List<String> rules = new ArrayList<>();
rules.add("30003");
rules.add("20002");
rules.add("10001");
rules.add("40004");
rules.add("60006");
rules.add("50005");
Map<String, Integer> ruleUpper = new HashMap<>();
ruleUpper.put("10001", 1);
ruleUpper.put("20002", 2);
ruleUpper.put("30003", 3);
ruleUpper.put("40004", 4);
Collections.sort(rules, new Comparator<String>() {
@Override
public int compare(String o1, String o2) {
return ruleUpper.getOrDefault(o1, Integer.MAX_VALUE) - ruleUpper.getOrDefault(o2, Integer.MAX_VALUE);
}
});
System.out.println(rules);
// [10001, 20002, 30003, 40004, 60006, 50005]
}
}
到了這里,關(guān)于Java List 按指定條件排序的幾種方式的文章就介紹完了。如果您還想了解更多內(nèi)容,請在右上角搜索TOY模板網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章,希望大家以后多多支持TOY模板網(wǎng)!