【Java实战】集合排序方法与长度获取方法辨析(易懂版)

一、排序方法

1. 对List排序的两种方式

方式一Collections.sort()

java 复制代码
List<Integer> numbers = Arrays.asList(3,1,4,2);
Collections.sort(numbers); // 直接修改原list → [1,2,3,4]

方式二:list.sort()(Java8推荐)

java 复制代码
List<String> fruits = new ArrayList<>(Arrays.asList("apple","banana","pear"));
fruits.sort(Comparator.comparing(String::length));
 // 按字符串长度排序

2. 对数组排序

java 复制代码
int[] arr = {5,2,7};
Arrays.sort(arr); 
// 数组变为[2,5,7]

3. 不修改原集合的排序(使用Stream)

java 复制代码
List<Integer> original = List.of(3,1,2);
List<Integer> sorted = original.stream()                              .sorted() .toList();
 // 新list [1,2,3]

二、获取长度/大小的方法

1. 数组用.length(属性)

java 复制代码
String[] names = {"Alice","Bob"};int len = names.length;
 // 2

2. 集合都用.size()

java 复制代码
 List<String> list = List.of("a","b","c");
 Set<Integer> set = Set.of(1,2,3);
 Map<String,Integer> map = Map.of("a",1,"b",2);
 int listSize = list.size();
  // 3
  int setSize = set.size();   
  // 3
  int mapSize = map.size();   
  // 2

3. 字符串用.length()

java 复制代码
String s = "hello";
int strLen = s.length();
 // 5

三、使用场景

  1. 需要排序List
  • 想直接修改原list → list.sort()
  • 想保留原list → 用Stream的sorted()
  1. 需要排序数组
  • 只能用Arrays.sort()
  1. 需要自动排序的集合
  • TreeSetTreeMap

四、常见问题解答

Q:为什么数组用length而集合用size?

A:这是Java的历史设计决定。数组是语言基础结构用字段(length),集合是类库用方法(size())

Q:sort()和sorted()区别?

A:

  • sort()直接修改原集合
  • sorted()产生新集合,原集合不变

Q:Set和Map也能排序吗?

A:

  • 普通HashSet/HashMap不能直接排序- 可以用TreeSet/TreeMap自动排序
  • 或者转为List再排序

五、实际例子

例子1:学生成绩排序

java 复制代码
List<Student> students =students.sort(Comparator.comparing(Student::getScore).reversed()); 
// 获取学生列表// 按成绩降序排序

例子2:统计单词频率并排序

java 复制代码
Map<String, Integer> wordCounts = List<Map.Entry<String, Integer>> top10 = wordCounts.entrySet().stream()    .sorted(Map.Entry.comparingByValue().reversed()).limit(10).toList();
// 单词计数map// 按频率排序取前10

例子3:混合类型排序

java 复制代码
List<Object> mixed = Arrays.asList("apple", 123, "banana", 45.6);
mixed.sort(Comparator.comparing(o -> o.toString().length())); 
// 按字符串长度排序

说明:

  1. 核心逻辑
  • Comparator.comparing(o -> o.toString().length()) :
    提取每个元素的字符串表示长度作为排序键,按升序排列(默认规则)。
  • 元素类型转换:
    所有元素通过 toString() 转为字符串,长度计算方式:
  • "apple" → 5
  • 123 → "123" → 3
  • "banana" → 6
  • 45.6 → "45.6" → 4
  1. 执行结果
    排序后列表顺序为:

    123, 45.6, apple, banana

    (按长度升序:3 → 4 → 5 → 6)

记住这个选择口诀:

数组排序用Arrays, 复制代码
集合排序用sort或sorted
,要问长度/大小是多少?
数组length集合size要记牢!
相关推荐
缺点内向2 小时前
Java:创建、读取或更新 Excel 文档
java·excel
带刺的坐椅2 小时前
Solon v3.4.7, v3.5.6, v3.6.1 发布(国产优秀应用开发框架)
java·spring·solon
四谎真好看4 小时前
Java 黑马程序员学习笔记(进阶篇18)
java·笔记·学习·学习笔记
桦说编程4 小时前
深入解析CompletableFuture源码实现(2)———双源输入
java·后端·源码
java_t_t4 小时前
ZIP工具类
java·zip
西阳未落4 小时前
LeetCode——二分(进阶)
算法·leetcode·职场和发展
lang201509285 小时前
Spring Boot优雅关闭全解析
java·spring boot·后端
pengzhuofan5 小时前
第10章 Maven
java·maven
百锦再6 小时前
Vue Scoped样式混淆问题详解与解决方案
java·前端·javascript·数据库·vue.js·学习·.net
刘一说6 小时前
Spring Boot 启动慢?启动过程深度解析与优化策略
java·spring boot·后端