Java:列表操作

目录


1、判断列表是否为空或者为NULL

java 复制代码
Optional.ofNullable(list).orElse(Collections.emptyList()).isEmpty()  // true=为空或NULL false 不为空或NULL

2、列表包含

java 复制代码
List<String> list = Arrays.asList("apple", "banana", "cherry");  
boolean containsApple = list.contains("apple"); // 返回 true  
boolean containsMango = list.contains("mango"); // 返回 false

3、列表排序

对象

java 复制代码
List<User> users = new ArrayList<>();
users.add(new User(1L, "张三", 18, 1));
users.add(new User(2L, "李四", 52, 1));
users.add(new User(3L, "王五", 36, 1));
users.add(new User(4L, "赵六", 36, 1));

// users.sort(Comparator.comparing(User::getAge));  // 正序
users.sort(Comparator.comparing(User::getId).reversed());  // 倒叙
//        users.sort(Comparator.comparing(User::getAge).thenComparing(User::getId));  // 多条件排序
System.out.println(users);

List<Map<>>

java 复制代码
List<Map<String, Object>> resultlist = new ArrayList<>();
Map<String, Object> map1 = new HashMap<String, Object>();
map1.put("id", "1");
map1.put("name", "张三");
map1.put("Score", 86.5);
Map<String, Object> map2 = new HashMap<String, Object>();
map2.put("id", "2");
map2.put("name", "李四");
map2.put("Score", 90.0);
Map<String, Object> map3 = new HashMap<String, Object>();
map3.put("id", "3");
map3.put("name", "王五");
map3.put("Score", 70.5);

resultlist.add(map1);
resultlist.add(map2);
resultlist.add(map3);

resultlist.sort((o1, o2) -> {
    Double one = Double.valueOf(o1.get("Score").toString());
    Double two = Double.valueOf(o2.get("Score").toString());
    return one.compareTo(two);  //one.compareTo(two)为升序,two.compareTo(one)为降序
});

List String

java 复制代码
List<String> headList = new ArrayList();
Collections.sort(headList);

4、列表截取

列表截取 --- 左闭右开

java 复制代码
List<User> users = new ArrayList<>();
users.add(new User(1L, "张三", 18, 1));
users.add(new User(2L, "李四", 52, 1));
users.add(new User(3L, "王五", 36, 1));
users.add(new User(4L, "赵六", 36, 1));
List<User> new_users = users.subList(0, 3);
for (User newUser : new_users) {
    System.out.println(newUser);
}

5、列表合并

java 复制代码
List<Integer> list1 = Arrays.asList(1, 2, 3);
List<Integer> list2 = Arrays.asList(4, 5, 6);
List<Integer> list3 = Arrays.asList(7, 8, 9);

List<Integer> mergedList = Stream.of(list1, list2, list3).flatMap(Collection::stream).collect(Collectors.toList());

System.out.println(mergedList);// [1, 2, 3, 4, 5, 6, 7, 8, 9]

6、列表求极值

注意:Collections是java.util包下的

java 复制代码
List<Integer> list = Arrays.asList(1, 2, 3, 4, 5, 6, 7, 8, 9);
Integer max = Collections.max(list);
Integer min = Collections.min(list);
System.out.println("最大值:" + max + "最小值:" + min);

7、列表转字符串

java 复制代码
// 创建一个字符串列表
List<String> list = Arrays.asList("apple", "banana", "cherry");
// 使用String.join()方法将列表转换为字符串
String str = String.join(", ", list);
// 输出结果
System.out.println(str); // 输出: apple, banana, cherry

8、列表去重的四种方式

使用Set接口进行去重,但是需要注意的是这样去重会打乱原来List中数据的顺序。

java 复制代码
List<Integer> list = Arrays.asList(1, 2, 3, 2, 4, 4, 5, 5, 6);  
Set<Integer> set = new HashSet<>(list);  
List<Integer> deduplicatedList = new ArrayList<>(set);  
System.out.println(deduplicatedList); // 输出: [1, 2, 3, 4, 5, 6]

使用LinkedHashSet保留插入顺序

java 复制代码
List<Integer> list = Arrays.asList(1, 2, 3, 2, 4, 4, 5, 5, 6);  
Set<Integer> set = new LinkedHashSet<>(list);  
List<Integer> deduplicatedList = new ArrayList<>(set);  
System.out.println(deduplicatedList); // 输出: [1, 2, 3, 4, 5, 6],保持了插入顺序

使用stream流进行去重

java 复制代码
List<Integer> list = Arrays.asList(1, 2, 3, 2, 4, 4, 5, 5, 6);  
List<Integer> deduplicatedList = list.stream().distinct().collect(Collectors.toList());  
System.out.println(deduplicatedList); // 输出: [1, 2, 3, 4, 5, 6]

手动去重

java 复制代码
List<Integer> list = Arrays.asList(1, 2, 3, 2, 4, 4, 5, 5, 6);  
List<Integer> deduplicatedList = new ArrayList<>();  
Set<Integer> set = new HashSet<>();  
for (Integer item : list) {  
    if (set.add(item)) { // 如果添加成功,说明是第一次遇到这个元素  
        deduplicatedList.add(item);  
    }  
}  
System.out.println(deduplicatedList); // 输出: [1, 2, 3, 4, 5, 6] 

以上四种方式都可以完成对List列表的去重操作,可以根据自己的实际情况任选其一。

9、列表转数组

java 复制代码
csList.stream().toArray(String[]::new)
相关推荐
蓝澈11212 分钟前
弗洛伊德(Floyd)算法-各个顶点之间的最短路径问题
java·数据结构·动态规划
再见晴天*_*10 分钟前
logback 日志不打印
java·服务器·logback
之歆13 分钟前
Python-封装和解构-set及操作-字典及操作-解析式生成器-内建函数迭代器-学习笔记
笔记·python·学习
幽络源小助理18 分钟前
SpringBoot基于JavaWeb的城乡居民基本医疗信息管理系统
java·spring boot·学习
欧阳有财21 分钟前
[java八股文][Mysql面试篇]日志
java·mysql·面试
TDengine (老段)30 分钟前
使用 StatsD 向 TDengine 写入
java·大数据·数据库·时序数据库·iot·tdengine·涛思数据
真实的菜33 分钟前
JVM类加载系统详解:深入理解Java类的生命周期
java·开发语言·jvm
天天爱吃肉82181 小时前
ZigBee通信技术全解析:从协议栈到底层实现,全方位解读物联网核心无线技术
python·嵌入式硬件·物联网·servlet
N_NAN_N1 小时前
类图+案例+代码详解:软件设计模式----原型模式
java·设计模式·原型模式
佛祖保佑永不宕机1 小时前
maven引入本地jar包
java·maven·jar