在spring boot 项目中远程调用时,如果使用subList()方法报错原因分析

在spring boot 项目调式中,接口一直报错,后来才发现是因为在微服务中,远程调用接口时,如果方法中包含 ArrayList.subList()方法会导致异常。

在 Spring Boot 项目中,远程调用(如通过 REST API 或 RPC)时,如果方法中使用了 ArrayList.subList(),可能会遇到一些问题。这是因为 subList() 返回的是一个视图(Sublist),而不是一个新的 ArrayList 实例。这种视图在某些情况下可能会导致远程调用无法正确识别或序列化。

  1. ArrayList.subList()的特性

ArrayList.subList(int fromIndex, int toIndex) 返回的是原始列表的一个视图(Sublist),而不是一个新的独立列表。这个视图与原始列表共享数据,但对视图的修改会反映到原始列表中,反之亦然。

java 复制代码
List<String> originalList = new ArrayList<>(Arrays.asList("A", "B", "C", "D"));
List<String> subList = originalList.subList(1, 3); // 返回 ["B", "C"]
subList.set(0, "X"); // 修改 subList
System.out.println(originalList); // 输出 [A, X, C, D]
  1. 远程调用时发生的问题

在远程调用中,数据通常需要序列化和反序列化(如JSON或二进制格式),而ArrayList.subList()返回的SubList是一个内部类,可能无法被序列化框架(如jackson,gson或这kryo)正确处理,导致发生异常:

序列化失败:SubList 可能无法被序列化为json或者其他格式

反序列化失败:远程调用接受方可能无法将数据反序列化为subList。

类型不匹配:接收方期望是一个ArrayList,但实际接收到的是一个subList,导致类型转换异常。

  1. 解决办法

为避免出现这些问题,可以在远程调用中避免直接使用subList(),而是将其转化为内ArraList或者其他可序列化的集合类型。

3.1 转换为新的ArrayList

java 复制代码
List<String> originalList = new ArrayList<>(Arrays.asList("A", "B", "C", "D"));
List<String> subList = new ArrayList<>(originalList.subList(1, 3)); // 转换为新的 ArrayList

3.2 使用streamApi进行转换

java 复制代码
List<String> originalList = new ArrayList<>(Arrays.asList("A", "B", "C", "D"));
List<String> subList = originalList.stream()
                                   .skip(1)
                                   .limit(2)
                                   .collect(Collectors.toList());

3.3 使用手动复制(不推荐)

java 复制代码
List<String> originalList = new ArrayList<>(Arrays.asList("A", "B", "C", "D"));
List<String> subList = new ArrayList<>();
for (int i = 1; i < 3; i++) {
    subList.add(originalList.get(i));
}
  1. 总结

ArrayList.subList()返回的是一个视图(subList),而不是一个新的独立列表。

在远程调用中,subList可能会导致序列化或者反序列化的问题。

解决方法是把subList()的结果转换为新的ArrayList或者其他可序列化的集合类型,确保在远程调用时能够正常进行序列化和反序列化,保证数据能够正确传输和处理。

相关推荐
uzong2 小时前
技术故障复盘模版
后端
GetcharZp2 小时前
基于 Dify + 通义千问的多模态大模型 搭建发票识别 Agent
后端·llm·agent
桦说编程3 小时前
Java 中如何创建不可变类型
java·后端·函数式编程
lifallen3 小时前
Java Stream sort算子实现:SortedOps
java·开发语言
IT毕设实战小研3 小时前
基于Spring Boot 4s店车辆管理系统 租车管理系统 停车位管理系统 智慧车辆管理系统
java·开发语言·spring boot·后端·spring·毕业设计·课程设计
wyiyiyi3 小时前
【Web后端】Django、flask及其场景——以构建系统原型为例
前端·数据库·后端·python·django·flask
没有bug.的程序员3 小时前
JVM 总览与运行原理:深入Java虚拟机的核心引擎
java·jvm·python·虚拟机
一只爱撸猫的程序猿4 小时前
使用Spring AI配合MCP(Model Context Protocol)构建一个"智能代码审查助手"
spring boot·aigc·ai编程
甄超锋4 小时前
Java ArrayList的介绍及用法
java·windows·spring boot·python·spring·spring cloud·tomcat
阿华的代码王国4 小时前
【Android】RecyclerView复用CheckBox的异常状态
android·xml·java·前端·后端