慕田峪4524236
您可以使用 Comparator 链。List<String> fruits = new ArrayList<>(Arrays.asList( "Apple", "Banana", "Orange", "Watermelon", "Peach"));fruits.sort(Comparator.comparing((String s) -> !s.contains("O") && !s.contains("o")) .thenComparing(Comparator.naturalOrder()));System.out.println(fruits.stream().collect(Collectors.joining(", ")));第一个比较器查看字符串是否包含 O 使那些先行,第二个比较器使用自然顺序。注意:Boolean.TRUE.compareTo(Boolean.FALSE) > 0为了让包含 O 的字符串先走,我用一个!这打印Orange, Watermelon, Apple, Banana, Peach注意:在这种情况下,new ArrayList<>( ... )不需要,因为sort不会改变元素的数量,只是重新排列它们。编辑:基于@Holger 的建议。如果首选稳定排序,即尽可能保持顺序不变。List<String> fruits = Arrays.asList( "Watermelon", "Peach", "Orange", "Banana", "Apple");fruits.sort(Comparator.comparing((String s) -> !s.contains("O") && !s.contains("o")));System.out.println(fruits.stream().collect(Collectors.joining(", ")));印刷Watermelon, Orange, Peach, Banana, Apple